精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

網(wǎng)站如何做到完全不需要jQuery

開發(fā) 前端
據(jù)統(tǒng)計,目前全世界57.3%的網(wǎng)站使用它。也就是說,10個網(wǎng)站里面,有6個使用jQuery。如果只考察使用工具庫的網(wǎng)站,這個比例就會上升到驚人的91.7%。

jQuery是現(xiàn)在最流行的JavaScript工具庫。

據(jù)統(tǒng)計,目前全世界57.3%的網(wǎng)站使用它。也就是說,10個網(wǎng)站里面,有6個使用jQuery。如果只考察使用工具庫的網(wǎng)站,這個比例就會上升到驚人的91.7%。

雖然jQuery如此受歡迎,但是它臃腫的體積也讓人頭痛不已。jQuery 2.0的原始大小為235KB,優(yōu)化后為81KB;如果是支持IE6、7、8的jQuery 1.8.3,原始大小為261KB,優(yōu)化后為91KB。

這樣的體積,即使是寬帶環(huán)境,完全加載也需要1秒或更長,更不要說移動設(shè)備了。這意味著,如果你使用了jQuery,用戶至少延遲1秒,才能看到網(wǎng)頁效果??紤]到本質(zhì)上,jQuery只是一個操作DOM的工具,我們不僅要問:如果只是為了幾個網(wǎng)頁特效,是否有必要動用這么大的庫?

[[72564]]

2006年,jQuery誕生的時候,主要用于消除不同瀏覽器的差異(主要是IE6),為開發(fā)者提供一個簡潔的統(tǒng)一接口。相比當時,如今的情況已經(jīng)發(fā)生了很大的變化。IE的市場份額不斷下降,以ECMAScript為基礎(chǔ)的JavaScript標準語法,正得到越來越廣泛的支持。開發(fā)者直接使用JavScript標準語法,就能同時在各大瀏覽器運行,不再需要通過jQuery獲取兼容性。

下面就探討如何用JavaScript標準語法,取代jQuery的一些主要功能,做到j(luò)Query-free。

[[72565]]

一、選取DOM元素

jQuery的核心是通過各種選擇器,選中DOM元素,可以用querySelectorAll方法模擬這個功能。

  1. var $ = document.querySelectorAll.bind(document); 

這里需要注意的是,querySelectorAll方法返回的是NodeList對象,它很像數(shù)組(有數(shù)字索引和length屬性),但不是數(shù)組,不能使用pop、push等數(shù)組特有方法。如果有需要,可以考慮將Nodelist對象轉(zhuǎn)為數(shù)組。

  1. myList = Array.prototype.slice.call(myNodeList); 

二、DOM操作

DOM本身就具有很豐富的操作方法,可以取代jQuery提供的操作方法。

尾部追加DOM元素。

  1. // jQuery寫法  
  2.   $(parent).append($(child));  
  3.  
  4. // DOM寫法  
  5.   parent.appendChild(child) 

頭部插入DOM元素。

  1.   // jQuery寫法  
  2.   $(parent).prepend($(child));  
  3.  
  4.   // DOM寫法  
  5.   parent.insertBefore(child, parent.childNodes[0]) 

刪除DOM元素。

  1. // jQuery寫法  
  2.   $(child).remove()  
  3.  
  4. // DOM寫法  
  5.   child.parentNode.removeChild(child) 

三、事件的監(jiān)聽

jQuery的on方法,完全可以用addEventListener模擬。

  1. Element.prototype.on = Element.prototype.addEventListener; 

為了使用方便,可以在NodeList對象上也部署這個方法。

  1.   NodeList.prototype.on = function (event, fn) {  
  2.     []['forEach'].call(thisfunction (el) {  
  3.       el.on(event, fn);  
  4.     });  
  5.     return this;  
  6.   }; 

四、事件的觸發(fā)

jQuery的trigger方法則需要單獨部署,相對復(fù)雜一些。

  1.   Element.prototype.trigger = function (type, data) {  
  2.     var event = document.createEvent('HTMLEvents');  
  3.     event.initEvent(type, truetrue);  
  4.     event.data = data || {};  
  5.     event.eventName = type;  
  6.     event.target = this;  
  7.     this.dispatchEvent(event);  
  8.     return this;  
  9.   }; 

在NodeList對象上也部署這個方法。

  1.   NodeList.prototype.trigger = function (event) {  
  2.     []['forEach'].call(thisfunction (el) {  
  3.       el['trigger'](event);  
  4.     });  
  5.     return this;  
  6.   }; 

五、document.ready

目前的最佳實踐,是將JavaScript腳本文件都放在頁面底部加載。這樣的話,其實document.ready方法(jQuery簡寫為$(function))已經(jīng)不必要了,因為等到運行的時候,DOM對象已經(jīng)生成了。

#p#

六、attr方法

jQuery使用attr方法,讀寫網(wǎng)頁元素的屬性。

  1.  $("#picture").attr("src""http://url/to/image"); 

DOM元素允許直接讀取屬性值,寫法要簡潔許多。

  1.   $("#picture").src = "http://url/to/image"

需要注意,input元素的this.value返回的是輸入框中的值,鏈接元素的this.href返回的是絕對URL。如果需要用到這兩個網(wǎng)頁元素的屬性準確值,可以用this.getAttribute('value')和this.getAttibute('href')。

七、addClass方法

jQuery的addClass方法,用于為DOM元素添加一個class。

  1. $('body').addClass('hasJS'); 

DOM元素本身有一個可讀寫的className屬性,可以用來操作class。

  1.   document.body.className = 'hasJS';  
  2.   // or  
  3.   document.body.className += ' hasJS';  

HTML 5還提供一個classList對象,功能更強大(IE 9不支持)。

  1.   document.body.classList.add('hasJS');  
  2.   document.body.classList.remove('hasJS');  
  3.   document.body.classList.toggle('hasJS');  
  4.   document.body.classList.contains('hasJS'); 

八、CSS

jQuery的css方法,用來設(shè)置網(wǎng)頁元素的樣式。

  1. $(node).css( "color""red" ); 

DOM元素有一個style屬性,可以直接操作。

  1.   element.style.color = "red";;  
  2.   // or  
  3.   element.style.cssText += 'color:red'

九、數(shù)據(jù)儲存

jQuery對象可以儲存數(shù)據(jù)。

  1. $("body").data("foo", 52); 

HTML 5有一個dataset對象,也有類似的功能(IE 10不支持),不過只能保存字符串。

  1.   element.dataset.user = JSON.stringify(user);  
  2.   element.dataset.score = score; 

十、Ajax

jQuery的Ajax方法,用于異步操作。

  1.   $.ajax({  
  2.     type: "POST",  
  3.     url: "some.php",  
  4.     data: { name: "John", location: "Boston" }  
  5.   }).done(function( msg ) {  
  6.     alert( "Data Saved: " + msg );  
  7.   }); 

我們可以定義一個request函數(shù),模擬Ajax方法。

  1.   function request(type, url, opts, callback) {  
  2.     var xhr = new XMLHttpRequest();  
  3.     if (typeof opts === 'function') {  
  4.       callback = opts;  
  5.       opts = null;  
  6.     }  
  7.     xhr.open(type, url);  
  8.     var fd = new FormData();  
  9.     if (type === 'POST' && opts) {  
  10.       for (var key in opts) {  
  11.         fd.append(key, JSON.stringify(opts[key]));  
  12.       }  
  13.     }  
  14.     xhr.onload = function () {  
  15.       callback(JSON.parse(xhr.response));  
  16.     };  
  17.     xhr.send(opts ? fd : null);  
  18.   } 

然后,基于request函數(shù),模擬jQuery的get和post方法。

  1.   var get = request.bind(this'GET');  
  2.   var post = request.bind(this'POST'); 

十一、動畫

jQuery的animate方法,用于生成動畫效果。

  1. $foo.animate('slow', { x: '+=10px' }); 

jQuery的動畫效果,很大部分基于DOM。但是目前,CSS 3的動畫遠比DOM強大,所以可以把動畫效果寫進CSS,然后通過操作DOM元素的class,來展示動畫。

  1. foo.classList.add('animate'); 

如果需要對動畫使用回調(diào)函數(shù),CSS 3也定義了相應(yīng)的事件。

  1.   el.addEventListener("webkitTransitionEnd", transitionEnded);  
  2.  
  3.   el.addEventListener("transitionend", transitionEnded);  

十二、替代方案

由于jQuery體積過大,替代方案層出不窮。

其中,最有名的是zepto.js。它的設(shè)計目標是以最小的體積,做到最大兼容jQuery的API。zepto.js 1.0版的原始大小是55KB,優(yōu)化后是29KB,gzip壓縮后為10KB。

如果不求最大兼容,只希望模擬jQuery的基本功能,那么,min.js優(yōu)化后只有200字節(jié),而dolla優(yōu)化后是1.7KB。

此外,jQuery本身采用模塊設(shè)計,可以只選擇使用自己需要的模塊。具體做法參見它的github網(wǎng)站,或者使用專用的Web界面。

原文鏈接:http://www.ruanyifeng.com/blog/2013/05/jquery-free.html

責(zé)任編輯:林師授 來源: 阮一峰的網(wǎng)絡(luò)日志
相關(guān)推薦

2019-10-15 18:30:28

機械硬盤硬盤Windows 10

2014-12-10 10:45:56

Android應(yīng)用權(quán)限

2009-11-20 11:37:11

Oracle完全卸載

2023-02-14 15:00:38

開發(fā)者ChatGPT

2021-05-27 12:04:57

M1芯片漏洞惡意軟件

2017-03-13 13:54:40

戴爾

2012-08-23 09:50:07

測試測試人員軟件測試

2009-11-23 12:45:22

2011-11-09 15:49:52

API

2015-09-30 09:57:53

天分熱情工程師

2013-12-02 09:43:29

字符串編程

2015-08-20 10:56:19

算法界面開發(fā)

2024-02-22 09:00:00

LogitMat數(shù)據(jù)集算法

2021-12-12 22:20:47

Docker開發(fā)容器

2013-07-18 09:21:32

代碼文檔

2010-11-23 10:55:47

跳槽

2014-01-17 13:09:48

Linux碎片整理

2022-09-14 15:10:40

前端架構(gòu)

2022-02-15 07:26:34

web前端算法題

2018-01-29 13:18:42

前端JavaScript
點贊
收藏

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

欧美日韩激情在线| wwww国产精品欧美| 精品国产一区二区三区久久狼5月| 欧美日韩在线观看不卡| 国内三级在线观看| 国产在线精品一区二区不卡了| 美日韩丰满少妇在线观看| 一级欧美一级日韩片| 日韩一区二区三区在线免费观看 | 国产欧美日韩亚洲精品| www.男人天堂网| 婷婷色在线观看| 日本视频一区二区| 欧美福利在线观看| 日本性高潮视频| 91超碰在线免费| 狠狠色狠狠色综合系列| 久久免费视频在线观看| 蜜桃av免费观看| 欧美大片网址| 欧美一区二区三区四区久久| 亚洲三区在线| 日本wwwxxxx| 精品在线观看视频| 青青草99啪国产免费| 91人妻一区二区三区蜜臀| 午夜欧洲一区| 精品免费99久久| 一本色道久久亚洲综合精品蜜桃| 国产高清自产拍av在线| 亚洲精品视频在线| 亚洲国产欧美一区二区三区不卡| 熟妇人妻中文av无码| 国产一本一道久久香蕉| 国产精品国产亚洲伊人久久 | 国产欧美精品一区二区| 可以免费看的av毛片| 欧美精品入口| 久久精彩免费视频| 激情五月深爱五月| 国产精品免费99久久久| 日韩理论片久久| av在线播放亚洲| 超碰在线最新| 国产精品电影一区二区三区| 日本一区二区精品视频| 午夜在线观看视频18| 粉嫩一区二区三区性色av| 国产主播精品在线| 亚洲一卡二卡在线| 免费黄网站欧美| 国产精品九九九| 久久精品五月天| 久久永久免费| 日本高清视频一区| 永久免费无码av网站在线观看| 亚洲日韩视频| 欧美激情亚洲自拍| 国产奶水涨喷在线播放| 亚洲精品麻豆| 97在线看免费观看视频在线观看| 国产午夜免费视频| 国语精品一区| 高清欧美电影在线| 日韩成人免费在线观看| 夜夜嗨网站十八久久| 亚洲色图17p| 新91视频在线观看| 国产成人免费av一区二区午夜| 欧美亚一区二区| 欧美大尺度做爰床戏| 黄色日韩网站| 欧美一区午夜精品| 中国老熟女重囗味hdxx| 中文字幕一区日韩精品| 精品日韩一区二区| 亚洲第一黄色网址| 欧美男gay| 日韩一区二区三区视频| 人妻体体内射精一区二区| 亚洲国产天堂| 欧美xxx久久| 国产又黄又粗又猛又爽的视频| 伊甸园亚洲一区| 3atv在线一区二区三区| 日韩高清在线一区二区| 一区二区三区视频播放| 日韩成人在线电影网| 欧美做受xxxxxⅹ性视频| 欧美mv日韩| 久久久久这里只有精品| 久久久免费高清视频| 婷婷伊人综合| 欧美激情一级欧美精品| 欧美日韩综合一区二区三区| 欧洲精品二区| 亚洲女与黑人做爰| 青青青国产在线观看| 日本精品不卡| 一区二区三区日韩欧美精品| av网站大全免费| 99久久婷婷国产综合精品首页| 欧美一区午夜精品| 精品无码在线视频| 99精品视频在线| 97人洗澡人人免费公开视频碰碰碰| 国产精品免费无遮挡无码永久视频| 国内精品在线播放| 开心色怡人综合网站| 老司机在线看片网av| 欧美国产国产综合| 欧美日韩综合精品| 国产一区久久精品| 色诱视频网站一区| 波多野结衣三级视频| 精品国产网站| 97国产在线视频| 一级黄色小视频| 26uuu精品一区二区| 日本a级片在线播放| 怡红院在线播放| 日本韩国一区二区| 亚洲熟女一区二区三区| 日韩欧美视频在线播放| 91成人在线观看国产| xxxx国产精品| 亚洲丝袜另类动漫二区| 蜜臀av午夜一区二区三区| 黑色丝袜福利片av久久| 成人444kkkk在线观看| 精品久久久久久久久久久久久久久久久久 | 精品久久一区二区三区蜜桃| 99久久精品无免国产免费 | 国产精品久久久对白| 888av在线| 欧美亚洲综合在线| 强伦人妻一区二区三区| 99精品福利视频| 999国内精品视频在线| 免费观看在线黄色网| 国产精品第五页| 国产精品人人妻人人爽人人牛| 久久精品国产亚洲5555| 欧美国产日韩精品| 国产99久一区二区三区a片 | 日韩精品大片| 性欧美1819sex性高清| 日韩精品在线视频| 成人毛片18女人毛片| 波多野结衣在线一区| www.成年人视频| 北条麻妃在线一区二区免费播放 | 黄色污网站在线观看| 日韩午夜电影av| 国产女片a归国片aa| 狠狠色狠狠色综合| 成人在线免费观看网址| 日韩欧美久久| 久久久免费在线观看| 欧美一级免费片| 婷婷久久综合九色综合绿巨人 | 久久精品欧美一区二区三区不卡 | 激情国产在线| 日韩精品久久久久久福利| 久久久久99精品成人片三人毛片| 久久尤物电影视频在线观看| 日本在线视频www| jiujiure精品视频播放| 国产日韩欧美一二三区| 黄色免费在线观看| 欧美成人bangbros| 日韩在线视频免费播放| 国产日韩成人精品| 自拍偷拍21p| 欧美日韩日本国产亚洲在线| 国产精品一区视频网站| 在线观看涩涩| 中文字幕久热精品在线视频| 国产精品久久久午夜夜伦鲁鲁| 亚洲欧美日韩国产一区二区三区 | 99久久99久久免费精品蜜臀| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 九九精品久久| 成人性生交大片免费观看嘿嘿视频 | 国产精品一区二区美女视频免费看 | 一本一道波多野毛片中文在线| 在线播放91灌醉迷j高跟美女| 麻豆精品一区二区三区视频| 99久久精品免费精品国产| 又色又爽又高潮免费视频国产| 五月天久久网站| 国产欧美精品一区二区三区| a日韩av网址| 久久中文字幕一区| 天天综合在线视频| 欧美视频在线一区| 免费观看一级视频| 日本一二三不卡| 美女扒开腿免费视频| 免费高清在线视频一区·| 免费在线黄网站| 国产一区二区三区四区五区| 亚洲自拍另类欧美丝袜| 日韩免费va| 欧美国产一区二区三区| 99中文字幕一区| 亚洲国产精品yw在线观看| 亚洲一区 中文字幕| 天天色 色综合| 欧美性猛交xxxxx少妇| 国产亚洲一区二区三区| 特级特黄刘亦菲aaa级| 麻豆视频一区二区| 大肉大捧一进一出好爽视频| 欧美成人tv| 亚洲激情一区二区| 性人久久久久| 国产chinese精品一区二区| 久久久久毛片| 日韩美女主播视频| 国产中文在线播放| 欧美国产日韩免费| av免费看在线| 日韩午夜在线视频| 成人在线观看黄色| 色久优优欧美色久优优| 欧美又粗又大又长| 国产精品看片你懂得| 加勒比综合在线| 91麻豆精品秘密| 日本一区二区在线观看视频| 国产在线播放一区二区三区| 亚洲 欧美 另类人妖| 日本视频一区二区三区| 亚洲中文字幕无码不卡电影| 黄色在线成人| 日韩欧美精品免费| 欧美激情四色| 国产911在线观看| 婷婷久久一区| 久久wwww| 欧美mv日韩mv亚洲| 国产精品嫩草影院桃色| 欧美日韩一区二区三区高清| 日韩欧美国产另类| 欧美性生交xxxxxdddd| 这里只有精品在线观看视频| 国产精品888| 亚洲一区二区中文字幕在线观看| 免费人成在线不卡| 超碰在线播放91| 日本不卡视频一二三区| 青青草精品视频在线观看| 久久精品一区二区国产| 国产在线观看福利| 久热精品在线| 欧美精品aaaa| 蜜桃视频第一区免费观看| 亚洲成色www.777999| 奇米精品一区二区三区在线观看| 日本爱爱免费视频| 免费高清不卡av| 一区二区免费av| 国产精品theporn| 91看片淫黄大片91| 好看的亚洲午夜视频在线| 免费网站在线观看视频| 99国产精品| 97公开免费视频| 久久99精品久久久久久动态图 | 中文字幕影音先锋| 亚洲777理论| 天天干天天色综合| 欧美日韩一区小说| 精品国产免费无码久久久| 亚洲成人精品视频| 国内av一区二区三区| 久久精品夜夜夜夜夜久久| 国产探花视频在线观看| 欧洲精品在线视频| а天堂中文最新一区二区三区| 成人国产一区二区| 国产三级一区| 亚洲综合成人婷婷小说| 成人偷拍自拍| 欧美日韩在线观看一区二区三区| 国产国产精品| 精品久久久久久无码中文野结衣| 久久午夜影视| 免费网站在线观看黄| 石原莉奈在线亚洲三区| 中文字幕第17页| 成人免费视频网站在线观看| 在线免费观看日韩av| 日韩美女啊v在线免费观看| 日本在线观看视频网站| 欧美日韩性生活| 日本毛片在线观看| 色妞在线综合亚洲欧美| gogo久久| 国产在线播放91| 一本色道久久综合狠狠躁的番外| 91制片厂免费观看| 欧美黄色录像片| www.av毛片| 久久99国产精品久久99果冻传媒| 老司机免费视频| 成人欧美一区二区三区在线播放| 中文字幕亚洲高清| 日韩一区二区三区精品视频| 成年在线电影| 8x拔播拔播x8国产精品| 精品中文字幕一区二区三区| 欧美在线播放一区| 最新国产乱人伦偷精品免费网站| 色91精品久久久久久久久| 久久久久久久综合狠狠综合| 久久久久亚洲天堂| 欧美日本在线播放| 黄色片免费在线| 91成人天堂久久成人| 2021年精品国产福利在线| 综合一区中文字幕| 亚洲人成免费网站| 免费黄色福利视频| 国产 欧美在线| 国产suv精品一区二区68| 在线一区二区视频| 污污视频在线免费看| 久久99久久99精品免观看粉嫩| 精品美女一区| 日韩在线电影一区| 久久xxxx| 右手影院亚洲欧美| 欧美日韩精品国产| 人妻少妇精品无码专区久久| 欧美成人黑人xx视频免费观看| 欧美亚洲综合视频| 亚洲午夜高清视频| 免费亚洲电影在线| 国内精品卡一卡二卡三| 日本高清不卡在线观看| 手机亚洲第一页| 色妞一区二区三区| av亚洲一区| 亚洲黄色一区二区三区| 蜜桃一区二区三区在线观看| 性欧美一区二区| 91成人免费网站| 国产毛片在线看| 国产精品久久av| 欧美国产偷国产精品三区| 中文字幕亚洲欧洲| 亚洲视频中文字幕| 99久久亚洲精品日本无码| 粗暴蹂躏中文一区二区三区| 久久综合给合| 日本wwwcom| 99精品一区二区三区| 日本特级黄色片| 亚洲午夜久久久久久久| 久久精品 人人爱| 懂色av粉嫩av蜜臀av| 国产黑丝在线一区二区三区| 精品一级少妇久久久久久久| 亚洲国产精品999| 中文另类视频| 99亚洲精品视频| 国产99一区视频免费| 日韩成人免费观看| 一级做a爰片久久毛片美女图片| 四虎国产精品成人免费影视| 日本精品免费视频| 成人久久18免费网站麻豆 | 日韩欧美一区视频| 国产福利第一视频在线播放| 国产有码在线一区二区视频| 国模吧视频一区| 熟女俱乐部一区二区视频在线| 欧美最新大片在线看| 老司机在线看片网av| 国产一区二区三区黄| 日韩中文字幕1| 永久免费看片直接| 亚洲精品久久久久久久久久久久久 | 成人mm视频在线观看| 伊人久久大香线蕉精品| 国产风韵犹存在线视精品| 国产专区第一页| 日韩在线观看免费| 国内精品免费| 99久re热视频精品98| 成人av资源网站| 中文av免费观看| 亚洲男人7777| 国产精品视频首页| 欧美激情成人网| 亚洲欧美日韩成人高清在线一区| 青青草在线免费视频| 91传媒视频免费|