亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jQuery的三種bind/One/Live/On事件綁定使用方法

2019-11-19 17:26:34
字體:
來源:轉載
供稿:網友

本篇文章介紹了,關于jQuery新的事件綁定機制on()的使用技巧。需要的朋友參考下 

今天瀏覽jQuery的deprecated列表,發現live()和die()在里面了,趕緊看了一下,發現從jQuery1.7開始,jQuery引入了全新的事件綁定機制,on()和off()兩個函數統一處理事件綁定。因為在此之前有bind(),
live(),

delegate()等方法來處理事件綁定,jQuery從性能優化以及方式統一方面考慮決定推出新的函數來統一事件綁定方法并且替換掉以前的方法。

on(events,[selector],[data],fn)

events:一個或多個用空格分隔的事件類型和可選的命名空間,如"click"或"keydown.myPlugin" 。

selector:一個選擇器字符串用于過濾器的觸發事件的選擇器元素的后代。如果選擇器為null或省略,當它到達選定的元素,事件總是觸發。

data:當一個事件被觸發時要傳遞event.data給事件處理函數。

fn:該事件被觸發時執行的函數。 false 值也可以做一個函數的簡寫,返回false。

替換bind()

當第二個參數'selector'為null時,on()和bind()其實在用法上基本上沒有任何區別了,所以我們可以認為on()只是比bind()多了一個可選的'selector'參數,所以on()可以非常方便的換掉bind()

替換live()

在1.4之前相信大家非常喜歡使用live(),因為它可以把事件綁定到當前以及以后添加的元素上面,當然在1.4之后delegate()也可以做類似的事情了。live()的原理很簡單,它是通過document進行事件委派的,因此我們也可以使用on()通過將事件綁定到document來達到live()一樣的效果。

 live()寫法

 $('#list li').live('click', '#list li', function() { //function code here.}); 

on()寫法

$(document).on('click', '#list li', function() { //function code here.});

這里的關鍵就是第二個參數'selector'在起作用了。它是一個過濾器的作用,只有被選中元素的后代元素才會觸發事件。

替換delegate()

delegate()是1.4引入的,目的是通過祖先元素來代理委派后代元素的事件綁定問題,某種程度上和live()優點相似。只不過live()是通過document元素委派,而delegate則可以是任意的祖先節點。使用on()實現代理的寫法和delegate()基本一致。

delegate()的寫法

$('#list').delegate('li', 'click', function() { //function code here.});

on()寫法

$('#list').on('click', 'li', function() { //function code here.});

貌似第一個和第二個參數的順序顛倒了一下,別的基本一樣。

總結

jQuery推出on()的目的有2個,一是為了統一接口,二是為了提高性能,所以從現在開始用on()替換bind(),
live(),

delegate吧。尤其是不要再用live()了,因為它已經處于不推薦使用列表了,隨時會被干掉。如果只綁定一次事件,那接著用one()吧,這個沒有變化。

jQuery是 一款優秀的JavaScript框架,在舊版里主要用bind()方法,在新版里又多了兩種One(),Live(),下面介紹這幾種方法的使用:

1. bind/Unbind

在jquery的事件模型中,有兩個基本的事件綁 定函數,bind與unbind,這兩個函數的含義就是匹配頁面元素進行相關事件的處理。比如我們在JS中經常使用到的 onfocus,onblur,onmouseover,onmousedown等事件都可以作為bind的參數進行傳遞。

$("#id").bind('click',function(){alert('tt!')});

其中bind的第一個參數代表的含義是:事件類型(注意不需要加on),function中的代碼就是你要執行的邏輯 代碼
多個事件綁定:bind還允許你綁定多個事件,事件名字之間用空格隔開,例如:

$('a').bind('click mouseover',function(){

在最新的jquery1.4版本中,對bind方法進行了改進,你可以在bind方法傳入一個類JSON對象來一次綁定多 個事件處理函數。

$('a').bind({click:function(){alert('a');},mouseover:function(){alert('a again!')}

在function函數中,你還可以通過傳遞一個javaScript對 象給function方法,這個事件對象通常是可以省略的。
bind中還有一個參數data, 該參數一般情況下很少使用,通常為了解決在同一個方法中處理同一個變量時有很好的處理。

var productname="Sports Shoes";$('#Area').bind('click',function(){alert(productname);});
productname="necklace",$('#Area').bind('click',function(){alert(productname);});

由于變量productname被重新賦值,所以輸出的消息都是”necklace”,這里不了解可以去查閱下關于JavaScript的變量作用域,要 解決這個問題就必須使用到data參數,

var productname="Sports Shoes";$('#Area').bind('click',{pn:productname},function(){alert(event.data.pn);});productname="necklace",$('#Area').bind('click',{pn:productname},function(){alert(event.data.pn);});

2. One

為每一個匹配元素的特定事件(像click)綁定一個一次性的事件處理函數。該方法與bind方法的參數一樣,與bind方法的區別就是只對匹配元素的事 件處理執行一次,執行完之后,以后再也不會執行,當然重新發起web請求時它又會執行一次。

$('a').one('click',function(){alert('a');})

單擊頁面上的a元素后,彈出消息,除非用戶發起第二次請求,否則再次點擊a元素不會彈出消息對話框。

3. live

該方法主要是能處理動態添加的元素,給那些后添加的元素也一樣綁定事件。

$('a').live('click,function(){alert('show message!');})

然后如果我添加一個元素,

$('body').appnend('Another Element');

那么該元素也會被觸發事件處理函數alert。
另外,jQuery還提供了一些綁定這些標準事件類型的簡單方式,比如.click()用于簡化.bind(‘click')。

一共有以下這些事件名稱:blur, focus, focusin, focusout, load, resize, scroll, unload, click, dblclick, mousedown, mouseup, mousemove, mouseover, mouseout, mouseenter, mouseleave, change, select, submit, keydown, keypress, keyup, error 等。

下面看下jQuery中綁定事件bind() on() live() one()的異同

jQuery中綁定事件的四種方法,他們可以同時綁定一個或多個事件

      bind()-------------------------版本號小于3.0(在Jquery3.0中已經移除,相應unbind()也移除)

       live()--------------------------版本號小于1.7(在Jquery1.7中已經移除,相應die()也移除)

       delegate()-------------------版本號小于1.7(在Jquery1.7中已經移除)

       on()---------------------------版本號大于1.7(在Jquery1.7中添加,相應off()也添加)

A:bind()事件的用法

<title>綁定事件</title> <script src="js/jQuery1.11.1.js" type="text/javascript"></script> <script>  $(function () {   $("p").bind({    "mouseover": function () {     $("p").css("background-color", "red");    },    "mouseout": function () {     $("p").css("background-color", "");    }   });  }); </script></head><body> <p>what are you doing?</p></body></html>

第一個最大的區別就是:bind()的事件綁定是只對當前頁面選中的元素有效。如果你想對動態創建的元素bind()事件,是沒有辦法達到效果的。

在后面的動態生成DOM元素綁定事件就要使用on();

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人免费高清完整版在线观看| 精品视频中文字幕| 国产日韩欧美综合| 欧美性xxxxxxx| 国产人妖伪娘一区91| 欧美韩国理论所午夜片917电影| 91精品中文在线| 国产精品一区二区三区毛片淫片| 欧美性理论片在线观看片免费| 亚洲国产精品电影在线观看| 国产精品三级久久久久久电影| 在线一区二区日韩| 成人性生交xxxxx网站| 日韩女优在线播放| 久久久久久久久久久免费精品| 精品色蜜蜜精品视频在线观看| 国产午夜精品视频| 日韩av理论片| 亚洲欧美日韩一区二区在线| 亚洲精品中文字幕有码专区| 韩国国内大量揄拍精品视频| 国产精品一区二区三| 久久精品国产99国产精品澳门| 日韩av在线免播放器| 国产精品久久91| 久久久久久久久国产| 亚洲另类激情图| 成人国产精品av| 97超碰国产精品女人人人爽| 日韩影视在线观看| 日韩日本欧美亚洲| 国产拍精品一二三| 色阁综合伊人av| 欧美性在线视频| 亚洲片国产一区一级在线观看| 欧美激情视频在线免费观看 欧美视频免费一| 中文字幕最新精品| 日韩视频永久免费观看| 中文字幕精品在线视频| 中文字幕成人精品久久不卡| 亚洲精品电影在线观看| 亚洲经典中文字幕| 精品视频在线观看日韩| 岛国精品视频在线播放| 欧美电影免费观看大全| 亚洲国产成人久久综合一区| 午夜精品视频网站| 亚洲欧美色图片| 国产一区二区三区丝袜| 日韩三级影视基地| 国产女人18毛片水18精品| 欧美激情精品久久久久久黑人| 琪琪第一精品导航| 日韩电视剧免费观看网站| 91中文精品字幕在线视频| 亚洲午夜激情免费视频| 久久免费福利视频| 国产美女搞久久| 欧美激情xxxx性bbbb| 日韩成人在线视频网站| 久久久久久久久久久久av| 欧美午夜丰满在线18影院| 精品在线观看国产| 欧美另类第一页| 一区二区三区视频观看| 日韩视频免费观看| 精品自拍视频在线观看| 亚洲片国产一区一级在线观看| 久久久中精品2020中文| 精品动漫一区二区| 91豆花精品一区| 国产深夜精品福利| 欧美综合第一页| 亚洲图片欧美日产| 一级做a爰片久久毛片美女图片| 亚洲性视频网址| 亚洲国产高清福利视频| 亚洲第一黄色网| 国产欧美日韩精品丝袜高跟鞋| 狠狠躁夜夜躁人人躁婷婷91| 国产www精品| 久久香蕉国产线看观看网| 亚洲最大av网| 97久久久久久| 久久久视频免费观看| 欧美黑人国产人伦爽爽爽| 久久在线免费视频| 日本一欧美一欧美一亚洲视频| 91久久在线播放| 欧美激情伊人电影| 91在线视频免费| 亚洲在线免费视频| 亚洲老头老太hd| 国产精品久久久久久久久借妻| 成年无码av片在线| 国产成人亚洲综合| 亚洲精品小视频在线观看| 久久久久免费精品国产| 亚洲欧美国产精品久久久久久久| 国产亚洲成av人片在线观看桃| 国产亚洲一区二区在线| 国产亚洲精品综合一区91| 欧美精品videossex88| 中文字幕日韩免费视频| 国产亚洲精品久久久久动| 亚州精品天堂中文字幕| 久久人人爽人人爽人人片av高清| 456国产精品| 欧美丝袜美女中出在线| 久久久精品一区| 国产精品亚洲一区二区三区| 久久久久久av| 一区二区欧美亚洲| 久久亚洲精品国产亚洲老地址| 亚洲性生活视频在线观看| 美女久久久久久久| 中文字幕免费精品一区高清| 亚洲mm色国产网站| 午夜精品在线观看| 国产精品男女猛烈高潮激情| 97婷婷涩涩精品一区| 久久精品国产一区二区电影| 亚洲国产一区二区三区在线观看| 日韩成人在线视频| 久久久久久尹人网香蕉| 亚洲欧洲美洲在线综合| 人妖精品videosex性欧美| 国产精品电影网| 亚洲男人天堂2023| 久久不射热爱视频精品| 91最新在线免费观看| 一区二区三区 在线观看视| 成人黄色在线播放| 成人乱色短篇合集| 日韩在线欧美在线| 日韩欧美有码在线| 欧美一区二区三区四区在线| 国产精品丝袜视频| 亚洲精品国产欧美| 中文字幕综合在线| 亚洲午夜av久久乱码| 亚洲日本成人网| 一区二区成人精品| 亚洲女人天堂视频| 欧美成年人视频网站| 亚洲天堂av在线免费| 国内自拍欧美激情| 国产精品xxxxx| 国产精品av免费在线观看| 欧美男插女视频| 亚洲国产私拍精品国模在线观看| 亚洲精品一区二区三区婷婷月| 国产一区二区三区丝袜| 亚洲成人黄色网址| 亚洲精选在线观看| 黑人与娇小精品av专区| 欧美久久久精品| 国产不卡av在线免费观看| 日韩视频中文字幕| 91精品久久久久久久久不口人| 国模精品视频一区二区三区| 欧美日韩亚洲一区二| 久久成人精品电影| 亚洲欧美三级在线|