DOM遍歷是昂貴的,所以盡量將會重複使用的元素快取。
// 糟糕h = $('#element').height(); $('#element').css('height',h-20);// 建议$element = $('#element'); h = $element.height(); $element.css('height',h-20);
jQuery與javascript一樣,一般來說,最好確保你的變數在函數作用域內。
// 糟糕$element = $('#element'); h = $element.height(); $element.css('height',h-20);// 建议var $element = $('#element');var h = $element.height(); $element.css('height',h-20);
在變數前面加上$前綴,方便辨識出jQuery物件。
// 糟糕var first = $('#first');var second = $('#second');var value = $first.val();// 建议 - 在jQuery对象前加$前缀var $first = $('#first');var $second = $('#second'),var value = $first.val();
將多條var語句合併為一條語句,我建議將未賦值的變數放到後面。
var $first = $('#first'), $second = $('#second'), value = $first.val(), k = 3, cookiestring = 'SOMECOOKIESPLEASE', i, j, myArray = {};
在新版jQuery中,更短的 on(“click”) 用來取代類似 click() 這樣的函數。在之前的版本中 on() 就是 bind()。自從jQuery 1.7版本後,on() 附加事件處理程序的首選方法。然而,出於一致性考慮,你可以簡單的全部使用 on()方法。
// 糟糕$first.click(function(){ $first.css('border','1px solid red'); $first.css('color','blue'); }); $first.hover(function(){ $first.css('border','1px solid red'); })// 建议$first.on('click',function(){ $first.css('border','1px solid red'); $first.css('color','blue'); }) $first.on('hover',function(){ $first.css('border','1px solid red'); })
一般來說,最好盡可能合併函數。
// 糟糕$first.click(function(){ $first.css('border','1px solid red'); $first.css('color','blue'); });// 建议$first.on('click',function(){ $first.css({'border':'1px solid red','color':'blue'}); });
jQuery實作方法的鍊式運算是非常容易的。下面利用這一點。
// 糟糕$second.html(value); $second.on('click',function(){ alert('hello everybody'); }); $second.fadeIn('slow'); $second.animate({height:'120px'},500);// 建议$second.html(value); $second.on('click',function(){ alert('hello everybody'); }).fadeIn('slow').animate({height:'120px'},500);
伴隨著精簡程式碼和使用鍊式的同時,可能帶來程式碼的難以閱讀。加入縮緊和換行能起到很好的效果。
$second.html(value); $second.on('click',function(){ alert('hello everybody'); }).fadeIn('slow').animate({height:'120px'},500);// 建议$second.html(value); $second .on('click',function(){ alert('hello everybody');}) .fadeIn('slow') .animate({height:'120px'},500);
短路求值是一個從左到右求值的表達式,用&&(邏輯與)或||(邏輯或)操作符。
// 糟糕function initVar($myVar) {if(!$myVar) { $myVar = $('#selector'); } }// 建议function initVar($myVar) { $myVar = $myVar || $('#selector'); }
#精簡程式碼的其中一種方式是利用程式設計捷徑。
// 糟糕if(collection.length > 0){..}// 建议if(collection.length){..}
如果你打算對DOM元素做大量操作(連續設定多個屬性或css樣式),建議先分開元素然後在添加。
// 糟糕var$container = $("#container"), $containerLi = $("#container li"), $element = null; $element = $containerLi.first();//... 许多复杂的操作// bettervar$container = $("#container"), $containerLi = $container.find("li"), $element = null; $element = $containerLi.first().detach();//... 许多复杂的操作$container.append($element);
你可能對使用jQuery中的方法缺少經驗,一定要查看的文檔,可能會有一個更好或更快的方法來使用它。
// 糟糕$('#id').data(key,value);// 建议 (高效)$.data('#id',key,value);
如前面所提到的,DOM遍歷是一項昂貴的操作。典型做法是快取父元素並在選擇子元素時重複使用這些快取元素。
// 糟糕var$container = $('#container'), $containerLi = $('#container li'), $containerLiSpan = $('#container li span');// 建议 (高效)var$container = $('#container '), $containerLi = $container.find('li'), $containerLiSpan= $containerLi.find('span');
將通用選擇子放到後代選擇符中,效能非常糟糕。
// 糟糕$('.container > *');// 建议$('.container').children();
通用選擇符有時是隱式的,不容易發現。
// 糟糕$('.someclass :radio');// 建议$('.someclass input:radio');
例如,Id選擇符應該是唯一的,所以沒有必要添加額外的選擇符。
// 糟糕$('div#myid'); $('div#footer a.myLink');// 建议$('#myid'); $('#footer .myLink');
在此強調,ID 選擇符應該是唯一的,不需要添加額外的選擇符,更不需要多個後代ID選擇符。
// 糟糕$('#outer #inner');// 建议$('#inner');
新版本通常更好:更輕量級,更有效率。顯然,你需要考慮你要支援的程式碼的兼容性。例如,2.0版本不支援ie 6/7/8。
關注每個新版本的廢棄方法是非常重要的並儘量避免使用這些方法。
// 糟糕 - live 已经废弃$('#stuff').live('click', function() { console.log('hooray'); });// 建议$('#stuff').on('click', function() { console.log('hooray'); });// 注:此处可能不当,应为live能实现实时绑定,delegate或许更合适
Google的CND能保證選擇離用戶最近的快取並迅速回應。 (使用GoogleCND請自行搜尋地址,此處地址不能使用,推薦jquery官網提供的CDN)。
如上所述,jQuery就是javascript,這意味著用jQuery能做的事情,同樣可以用原生程式碼來做。原生程式碼(或vanilla)的可讀性和可維護性可能不如jQuery,而且程式碼更長。但也意味著更有效率(通常更接近底層程式碼可讀性越差,效能越高,例如:彙編,當然需要更強大的人才可以)。牢記沒有任何框架能比原生程式碼更小,更輕,更有效率(註:測試連結已失效,可上網搜尋測試程式碼)。
鑑於vanilla 和 jQuery之間的效能差異,我強烈建議吸收兩人的精華,使用(可能的話)和jQuery等價的原生程式碼。
jQuery的編寫原則:
一、不要過度使用jQuery
1. jQuery速度再快,也無法與原生的javascript方法相比,而且建立的jQuery物件包含的資訊量很龐大。所以有原生方法可以使用的場合,盡量避免使用jQuery。
2. 許多jQuery方法都有兩個版本,一個是供jQuery物件使用的版本,另一個是供jQuery函數使用的版本。由於後者不透過jQuery物件操作,所以相對開銷較小,速度比較快。
以上是提高jQuery程式碼效率的編寫技巧總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!