Jquery中綁定事件bind與live的區別介紹
(1)target.click (function(){});
(2)target.bind("click",function(){});
# (3)target.live("click",function(){});
#第一種方法很好理解,其實就跟普通JS的用法差不多,只是少了一個on而已
第二、三種方法都是綁定事件,但是二者又有很大的不同,下面著重講解一下,因為這個如果用到Jquery的框架的話是用的挺多的,尤其要注意二者的區別。
【bind與live的差別】
live方法其實是bind方法的變種,其基本功能就同bind方法的功能是一樣的,都是為一個元素綁定某個事件,但是bind方法只能給當前存在的元素綁定事件,對於事後採用JS等方式新生成的元素無效,而live方法則正好彌補了bind方法的這個缺陷,它可以對後產生的元素也可以綁定對應的事件。那麼live方法的這個特性是怎麼實現的呢?以下來探討一下其實作原理。
live方法之所以能對後產生的元素也綁定對應的事件的原因歸結在「事件委託#」上面,所謂「事件委託」就是指綁定在祖先元素上的事件可以在其後代元素上使用。 live方法的處理機制就是把事件綁定在DOM樹的根節點上,而不是直接綁定在某個元素上。舉一個例子來說明:
$(".clickMe").live("click",fn); $("body").append("<p class='clickMe'>测试live方法的步骤</p>");
# 當我們點選這個新增的元素時會依序發生以下步驟:
(1)產生一個click事件,傳遞給p來做處理
(2)因沒有直接事件而直接綁定在p上,所以事件直接冒泡到DOM樹上
(3)事件不斷冒泡,直到DOM樹的根節點上,預設情況下,根節點上就綁定了這個click事件
(4)執行由live綁定的click事件
(5)偵測綁定事件的物件是否存在,判斷是否需要繼續執行綁定的事件。偵測事件物件是透過偵測
$(event.target).closest('.clickMe') 能找到符合的元素來實現的。
(6)透過(5)的測試,如果綁定事件的物件存在的話,就執行綁定的事件。
由於只有在事件發生的時候,live方法才會去偵測綁定事件的物件是否存在,所以live方法可以實現後來新增的元素也可實現事件的綁定。相較之下,bind會在事件在綁定階段就會判斷綁定事件的元素是否存在,而且只針對當前元素進行綁定,而不是綁定到父節點。
根據上面的分析,live的好處真是很大,那為什麼還要用bind方法呢?之所以jquery要保留bind方法而不是採用live方法去取代bind,也是因為live在某些情況下是無法完全取代bind的。 主要的差異如下:
(1)bind方法可以綁定任何JavaScript的事件,而live方法在jQuery1.3的時候只支援click, dblclick, keydown, keypress,
keyup,mousedown, mousemove, mouseout, mouseover, andmouseup.在j#Query 1.4.1中,甚至也支持focus 和blue
focus>#focus>#focus##focus##focus##focus>#focus##focus>#focus>事件了(映射到更
合適,並且可以冒泡的focusin和focusout上)。另外,在jQuery 1.4.1中,也能支援hover(映射
到"mouseenter mouseleave")。
(2)live() 並非完全支援透過DOM遍歷的方法所找到的元素。取而代之的是,應始終在一個選擇器後面直接使用 .live()
方法。
(3)當一個元素採用live方法進行事件的綁定的時候,如果想阻止事件的傳遞或冒泡,就要在函數中return false,僅僅調 以
###stopPropagation()是無法實現阻止事件的傳遞或冒泡的######以上是Jquery中綁定事件bind與live的區別介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

MetaMask(中文也叫小狐狸錢包)是一款免費的、廣受好評的加密錢包軟體。目前,BTCC已支援綁定MetaMask錢包,綁定後可使用MetaMask錢包進行快速登錄,儲值、買幣等,且首次綁定還可獲得20USDT體驗金。在BTCCMetaMask錢包教學中,我們將詳細介紹如何註冊和使用MetaMask,以及如何在BTCC綁定並使用小狐狸錢包。 MetaMask錢包是什麼? MetaMask小狐狸錢包擁有超過3,000萬用戶,是當今最受歡迎的加密貨幣錢包之一。它可免費使用,可作為擴充功能安裝在網絡

在現今這個資訊爆炸的時代,個人品牌和企業形象的建立變得越來越重要。小紅書作為國內領先的時尚生活分享平台,吸引了大量用戶關注和參與。對於那些希望擴大影響力、提高內容傳播效率的使用者來說,綁定子帳號成為了一種有效的手段。那麼,小紅書怎麼綁定子帳號呢?又如何檢測帳號是否正常呢?本文將為您詳細解答這些問題。一、小紅書怎麼綁定子帳號? 1.登入主帳號:首先,您需要登入您的小紅書主帳號。 2.開啟設定選單:點選右上角的“我”,然後選擇“設定”。 3.進入帳號管理:在設定選單中,找到「帳號管理」或「帳號助理」選項,點

1、打開今日頭條。 2、點選右下角我的。 3.點選【系統設定】。 4.點選【帳號和隱私設定】。 5.點選【抖音】右邊的按鈕即可綁定抖音。

jQuery中如何使用PUT請求方式?在jQuery中,發送PUT請求的方法與發送其他類型的請求類似,但需要注意一些細節和參數設定。 PUT請求通常用於更新資源,例如更新資料庫中的資料或更新伺服器上的檔案。以下是在jQuery中使用PUT請求方式的具體程式碼範例。首先,確保引入了jQuery庫文件,然後可以透過以下方式發送PUT請求:$.ajax({u

菜鳥app就是能夠提供你們各種物流資訊狀況的平台,這裡的功能非常的強大好用,大家有任何與物流相關的問題,都能在這得到解決的,反正都能為你們帶來一站式的服務,全都能及時解決的,查快遞,取快遞,寄快遞等,都是毫無任何問題,與各個的平台都進行了合作,全部的信息,都能查詢得到的,但是有些時候會出現拼多多當中購買的商品,都是無法呈現出物流的信息,其實是需要大家進行手動綁定拼多多,才能實現的,具體的方法已經整理出來了在下方,大家都能來看看的。菜鳥綁定拼多多帳戶的方法: 1、打開菜鳥APP,在主頁面

你們知道在使用菜鳥裹裹的時候是怎麼來綁定拼多多的嗎?菜鳥裹裹App官方正版在這款平台上面對於一些拼多多的物流信息是沒有自動同步上去的,我們需要做的就只能複製單號過來或是查詢你們的手機看看有無快遞的資訊。當然這些都是需要手動完成的,如果你們也想了解更多的話,就和小編一起來看看吧。 菜鳥APP怎麼綁定拼多多 1、打開菜鳥APP,在主頁點選左上角的「導包裹」。 2、在介面中,有許多購物網站,帳號都可以綁定。 3、點選導入其他電商平台。 4、使用者授權:點選拼多多到介面

最新小米最新推出的小米su7型號汽車霸佔了各種熱搜榜,許多正好有購車需求的用戶們都紛紛選擇了小米su7型號的汽車進行購買,那麼在提車以後如何利用自己的小米汽車app綁定家用充電樁充電呢,那麼這篇教學攻略就會為大家帶來詳細的內容介紹,希望能幫助大家。首先我們先打開小米手機app,點擊右下角我的按鈕然後在我的介面,可以看到家充樁的選項進入到綁定充電樁的頁面以後,點擊下方的去掃碼按鈕,掃描充電樁上的二維碼即可完成充電樁與app的綁定

標題:jQuery小技巧:快速修改頁面所有a標籤的文字在網頁開發中,我們經常需要對頁面中的元素進行修改和操作。使用jQuery時,有時候需要一次修改頁面中所有a標籤的文字內容,這樣可以節省時間和精力。以下將介紹如何使用jQuery快速修改頁面所有a標籤的文本,同時給出具體的程式碼範例。首先,我們需要引入jQuery庫文件,確保在頁面中引入了以下程式碼:<
