成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

對jQuery的事件綁定的一些思考

開發(fā) 前端
不管你用的是(click / bind / delegate)之中那個方法,最終都是jQuery底層都是調(diào)用on方法來完成最終的事件綁定。因此從某種角度來講除了在書寫的方便程度及習(xí)慣上挑選,不如直接都采用on方法來的痛快和直接。

問題

首先我們看下面的一個很常見的事件綁定代碼:

  1. //example  
  2. $('#dom').click(function(e){  
  3.   //do something  
  4. });  
  5.  
  6. $('#dom2').click(function(e){  
  7.   //do something  
  8. }); 

這段代碼在事件綁定處理上有一些缺陷:

1.過多的事件綁定會損耗內(nèi)存

2.后期生成HTML會沒有事件綁定,需要重新綁定

3.語法過于繁雜

解決方案

對于1、2兩點的解決方案,我們首先先了解一下jQuery的事件綁定

jQuery的事件綁定有多個方法可以調(diào)用,以click事件來舉例:

·click方法

·bind方法

·delegate方法

·on方法

不管你用的是(click / bind / delegate)之中那個方法,最終都是jQuery底層都是調(diào)用on方法來完成最終的事件綁定。因此從某種角度來講除了在書寫的方便程度及習(xí)慣上挑選,不如直接都采用on方法來的痛快和直接。

關(guān)于對方法的詳細解釋和用例,請直接訪問jQuery官網(wǎng),在這里不一一說明。api.jquery.com

性能

首先我們需要先對不同的事件綁定方式之間的內(nèi)存占用差距有一個清晰的認識。

對于性能的分析將采用Chrome的Developer Tools。

Profiles --> Take Heap Snapshot,用這個工具我們可以看到Javascript所占用的內(nèi)存,能夠?qū)π阅軉栴}進行分析。

DEMO HTML

  1. <html> 
  2.   <head> 
  3.     <script type="text/javascript"> 
  4.       $(function(){  
  5.         $('#btn-add').click(function(){  
  6.           $('.ul').prepend('<li><a href="javascript:;">text</a></li>');  
  7.         });  
  8.       });  
  9.     </script> 
  10.   </head> 
  11.   <body> 
  12.     <button id="btn-add">Create Element</button> 
  13.     <ul class="ul"> 
  14.       <li><a href="javascript:;">text</a></li> 
  15.       <!-- 2000 line... --> 
  16.       <li><a href="javascript:;">text</a></li> 
  17.     </ul> 
  18.   </body> 
  19. </html> 

Method 1

  1. $(function(){  
  2.     $('.ul a').click(function(e){  
  3.         alert('click event');  
  4.     });  
  5. }); 

以下是Method 1的內(nèi)存分析圖

內(nèi)存占用約3.4M

Method 2

  1. $(function(){  
  2.     $('.ul').on('click''a'function(e){  
  3.         alert('click event');  
  4.     });  
  5. }); 

以下是Method 2的內(nèi)存分析圖

內(nèi)存占用約2.0M

結(jié)論

1.Method 1 明顯比 Method 2 多耗1.4M的內(nèi)存

2.Method 1 無法將事件綁定到通過點擊button所新增DOM中來,而Method 2可以。

只要on的delegate對象是HTML頁面原有的元素,由于是事件的觸發(fā)是通過Javascript的事件冒泡機制來監(jiān)測,所以對于所有子元素(包括后期通過JS生成的元素)所有的事件監(jiān)測均能有效,且由于不用對多個元素進行事件綁定(在這個example中為2000+a標(biāo)簽),能夠有效的節(jié)省內(nèi)存的損耗。

#p#

思考

代碼如詩,但很容易變成代碼如屎。如何提高代碼的優(yōu)雅程度也是一個很有意思的事情。

以下是一個很普通且普遍的JS文件的代碼片段(用于一般網(wǎng)站)

  1. $('#btn-add').click(function(){  
  2.   //do something  
  3. });  
  4. $('.action-box #btn-delete').click(function(){  
  5.   //do something  
  6. });  
  7. $('.action-box #btn-sort').mouseenter(function(){  
  8.   //do something  
  9. });  
  10. /**  
  11. **more same code  
  12. */ 

毫不夸張的說,當(dāng)一個js文件上百行后,類似于上面的代碼,你很難從里面發(fā)現(xiàn)規(guī)律。

1.可能A喜歡寫#btn-add,而B喜歡寫.action-box #btn-add來作為選擇符。

2.堆砌著許多不同類型事件,沒有一個次序可言

3.沒有運用到我們剛剛所講的利用事件冒泡來做事件綁定

改進

我們來一步步改進一下之前的JS代碼

Version 1

  1. $('.action-box').on('click''#btn-add'function(){  
  2.   //do something  
  3. });  
  4. $('.action-box').on('click''#btn-delete'function(){  
  5.   //do something  
  6. }); 

雖然運用了事件冒泡,不過感覺還是有點累贅,.action-box出現(xiàn)多次,感覺不舒服,讓我們繼續(xù)改進

Version 2

  1. $('.action-box').on('click''#btn-add, #btn-delete'function(){  
  2.   if($(this).attr('id') == 'btn-add'){  
  3.     //do something  
  4.   } else{  
  5.     //do something  
  6.   }  
  7. }); 

感覺比剛剛好多了,不過還是需要判斷元素來做出相應(yīng)的處理,能接受,但不***。

靈感

首先看一下css的增強版本sass對于css語法上面的改進

  1. /*bed css code*/ 
  2. .action-box { width: 100%; color: #000; }  
  3. #btn-add { color: blue; }  
  4. #btn-delete { color: red; }  
  5.  
  6. /*good css code*/ 
  7. .action-box { width: 100%; color: #000; }  
  8.   .action-box #btn-add { color: blue; }  
  9.   .action-box #btn-delete { color: red; }  
  10.  
  11. /*sass code*/ 
  12. .action-box {  
  13.   width: 100%;  
  14.   color: #000;  
  15.   #btn-add {  
  16.     color: blue;  
  17.   }  
  18.   #btn-delete {  
  19.     color: red;  
  20.   }  

我們可以在 good css code 和 sass code 從中可以可以很清晰了然的看到文檔結(jié)構(gòu):.action-box 下面有兩個button。

這是否能讓sass這種代碼結(jié)構(gòu)運用到j(luò)s中來呢?答案當(dāng)然是可以。

  1. $('.action-box').coffee({  
  2.   click: {  
  3.     '#btn-add'function(){  
  4.       //do something  
  5.     },  
  6.     //這是是支持jQuery的':last / [attr] / :eq(0)'等方法的   
  7.     '#btn-delete'function(){  
  8.       //do something  
  9.     }  
  10.   },  
  11.   mouseenter: {  
  12.     '#btn-sort'function(){  
  13.       //do something  
  14.     }  
  15.   }  
  16. }); 

喜歡這種結(jié)構(gòu)嗎?

1.清晰明了的文檔結(jié)構(gòu)

2.運用事件冒泡,有效減少內(nèi)存的占用

3.***級別用事件名稱來劃分

4.第二級別的屬性名相當(dāng)于選擇符。

coffee函數(shù)的源碼

  1. $.fn.coffee = function(obj){  
  2.   for(var eName in obj)  
  3.     for(var selector in obj[eName])  
  4.       $(this).on(eName, selector, obj[eName][selector]);  

聊聊數(shù)行代碼,就可以做成一個很美妙的語法糖

責(zé)任編輯:張偉 來源: 博客園
相關(guān)推薦

2021-01-14 23:24:38

incaseforma蠕蟲病毒

2009-08-27 11:02:22

JavaScript事

2015-09-24 14:56:17

變革平臺開發(fā)云開發(fā)

2009-06-25 09:50:32

JSF

2020-02-03 16:03:36

疫情思考

2019-06-13 18:50:47

支付平臺架構(gòu)設(shè)計

2015-09-14 08:57:20

設(shè)計設(shè)計師

2011-11-30 15:57:18

2020-07-14 09:23:49

安全運營甲方乙方

2018-07-11 14:06:04

數(shù)據(jù)質(zhì)量數(shù)據(jù)治理數(shù)據(jù)清洗

2017-09-01 12:48:34

DevSecOps安全運維

2017-12-21 07:54:07

2019-09-17 09:21:01

2018-06-14 09:35:35

2011-08-01 10:37:29

軟件項目管理

2021-06-10 10:02:19

優(yōu)化緩存性能

2023-11-21 15:13:30

2022-12-27 09:56:34

架構(gòu)系統(tǒng)

2009-08-27 10:06:15

Scala的構(gòu)造方法

2018-07-23 12:03:01

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 99久久成人 | 91视频官网| 成人av一区二区三区 | 日本免费在线观看视频 | 久久久久久91 | 亚洲精品99999 | 国产在线精品一区二区 | 久久中文字幕一区 | 中文精品视频 | av网站免费观看 | 国产精品一区在线观看你懂的 | 伊人免费网 | 日韩欧美综合 | 日日噜噜噜夜夜爽爽狠狠视频, | www.操com| 亚洲精品视频在线看 | 色欧美片视频在线观看 | 国产高清在线精品 | 免费av手机在线观看 | 欧美视频xxx | 免费成人高清在线视频 | 国产成都精品91一区二区三 | 亚洲视频中文字幕 | 亚洲男人的天堂网站 | 欧美日韩专区 | 国产成都精品91一区二区三 | 6996成人影院网在线播放 | 欧美成视频在线观看 | 日韩在线 | 欧美久久一区二区三区 | 日本在线免费 | 一二区电影 | 国产一区免费 | 99久久精品一区二区成人 | 中国一级特黄真人毛片免费观看 | 国产精品一区久久久 | 91高清在线观看 | 久久国内精品 | 一级毛片中国 | 国产欧美一级二级三级在线视频 | 免费一区二区三区 |