目錄
用對選擇器
理解父子關係
做好快取
少改动DOM
尽量少生成jQuery对象
首頁 web前端 js教程 在jQuery中有關程式碼優化的詳細說明

在jQuery中有關程式碼優化的詳細說明

Jun 09, 2018 am 10:46 AM
jquery 程式碼最佳化

這篇文章為大家總結了關於jQuery程式碼最佳化方法,如果你這方面有需求,一起學習下吧。

用對選擇器

在jQuery中,可以用多種選擇器,選擇同一個網頁元素。每種選擇器的效能是不一樣的,應該要了解它們的效能差異

1、最快的選擇器:id選擇器和元素標籤選擇器

舉例來說,下面的語句效能最佳:

$('#id')
$('form')
$('input')
登入後複製

遇到這些選擇器的時候,jQuery內部會自動呼叫瀏覽器的原生方法(例如getElementById()),所以它們的執行速度快。

2、較慢的選擇器:class選擇器

$('.className')的效能,取決於不同的瀏覽器。 Firefox、Safari、Chrome、Opera瀏覽器,都有原生方法getElementByClassName(),所以速度不慢。但是,IE5-IE8都沒有部署這個方法,所以這個選擇器在IE中會相當慢

3、最慢的選擇器:偽類選擇器和屬性選擇器

找出網頁中所有的隱藏元素,就要用到偽類選擇器:

$(':hidden')
登入後複製

屬性選擇器的例子則是:

$('[attribute=value]')
登入後複製

這兩種語句是最慢的,因為瀏覽器沒有針對它們的原生方法。但是,一些瀏覽器的新版本,增加了querySelector()和querySelectorAll()方法,因此會使這類選擇器的性能有大幅提高

理解父子關係

下面六個選擇器,都是從父元素中選擇子元素

$('.child', $parent)
$parent.find('.child')
$parent.children('.child')
$('#parent > .child')
$('#parent .child')
$('.child', $('#parent'))
登入後複製

1、下面這條語句的意思是,給定一個DOM對象,然後從中選擇一個子元素。 jQuery會自動把這條語句轉成$.parent.find('child'),這會導致一定的效能損失。它比最快的形式慢了5%-10%

$('.child', $parent)
登入後複製

2、這條是最快的語句。 .find()方法會呼叫瀏覽器的原生方法(getElementById,getElementByName,getElementByTagName等等),所以速度較快

$parent.find('.child')
登入後複製

3、這條語句在jQuery內部,會使用$.sibling()和javascript的nextSibling()方法,一個個遍歷節點。它比最快的形式大約慢50%

$parent.children('.child')
登入後複製

4、jQuery內部使用Sizzle引擎,處理各種選擇器。 Sizzle引擎的選擇順序是從右到左,所以這條語句是先選.child,然後再一個個過濾出父元素#parent,這導致它比最快的形式大約慢70%

$('#parent > .child')
登入後複製

5、這條語句與上一條是同樣的情況。但是,上一條只選擇直接的子元素,這條可以選擇多層子元素,所以它的速度更慢,大概比最快的形式慢了77%

$('#parent .child')
登入後複製

6、jQuery內部會將這句語句轉成$('#parent').find('.child'),比最快的形式慢了23%

$('.child', $('#parent'))
登入後複製

所以,最佳選擇是$parent.find('. child')。而且,由於$parent往往在前面的操作已經生成,jQuery會進行緩存,所以進一步加快了執行速度

#不過度使用jQuery

jQuery速度再快,也無法與原生的javascript方法相比。所以有原生方法可以使用的場合,盡量避免使用jQuery。

以最簡單的選擇器為例,document.getElementById("foo")要比$("#foo")快10多倍

再來看一個例子,為a元素綁定一個處理點擊事件的函數:

$('a').click(function(){
    alert($(this).attr('id'));
  });
登入後複製

這段程式碼的意思是,點擊a元素後,彈出該元素的id屬性。為了取得這個屬性,必須連續兩次呼叫jQuery,第一次是$(this),第二次是attr('id')。

事實上,這種處理完全不必要。更正確的寫法是,直接採用javascript原生方法,呼叫this.id:

$('a').click(function(){
    alert(this.id);
  });
登入後複製

根據測試,this.id的速度比$(this).attr('id')快了20多倍

做好快取

選取某一個網頁元素,是開銷很大的步驟。所以,使用選擇器的次數應該越少越好,並且盡可能快取選取的結果,以便日後重複使用。

例如,下面這樣的寫法就是糟糕的寫法:

jQuery('#top').find('p.classA');
jQuery('#top').find('p.classB');
登入後複製

更好的寫法是:

var cached = jQuery('#top');
  cached.find('p.classA');
  cached.find('p.classB');
登入後複製

根據測試,快取比不緩存,快了2-3倍

jQuery的一大特點,就是允許使用鍊式寫法

$('p').find('h3').eq(2).html('Hello');
登入後複製

採用鍊式寫法時,jQuery自動快取每一步的結果,因此比非鍊式寫法要快。根據測試,鍊式寫法比(不使用快取的)非鍊式寫法,大約快了25%

事件委託

javascript的事件模型,採用"冒泡"模式,也就是說,子元素的事件會逐級向上"冒泡",成為父元素的事件。

利用這一點,可以大幅簡化事件的綁定。例如,有一個表格(table元素),裡面有100個格子(td元素),現在要求在每個格子上面綁定一個點擊事件(click),請問是否需要將下面的命令執行100次?

$("td").on("click", function(){
    $(this).toggleClass("click");
  });
登入後複製

回答是不需要,我們只要把這個事件綁定在table元素上面就可以了,因為td元素發生點擊事件之後,這個事件會"冒泡"到父元素table上面,從而被監聽到

因此,这个事件只需要在父元素绑定1次即可,而不需要在子元素上绑定100次,从而大大提高性能。这就叫事件的"委托处理",也就是子元素"委托"父元素处理这个事件

$("table").on("click", "td", function(){
    $(this).toggleClass("click");
  });
登入後複製

更好的写法,则是把事件绑定在document对象上面

$(document).on("click", "td", function(){
    $(this).toggleClass("click");
  });
登入後複製

如果要取消事件的绑定,就使用off()方法

$(document).off("click", "td");
登入後複製

少改动DOM

1、改动DOM结构开销很大,因此不要频繁使用.append()、.insertBefore()和.insetAfter()这样的方法

如果要插入多个元素,就先把它们合并,然后再一次性插入。根据测试,合并插入比不合并插入,快了将近10倍

2、如果要对一个DOM元素进行大量处理,应该先用.detach()方法,把这个元素从DOM中取出来,处理完毕以后,再重新插回文档。根据测试,使用.detach()方法比不使用时,快了60%

3、如果要在DOM元素上储存数据,不要写成下面这样:

var elem = $('#elem');
elem.data(key,value);
登入後複製

而要写成

var elem = $('#elem');
$.data(elem[0],key,value);
登入後複製

根据测试,后一种写法要比前一种写法,快了将近10倍。因为elem.data()方法是定义在jQuery函数的prototype对象上面的,而$.data()方法是定义jQuery函数上面的,调用的时候不从复杂的jQuery对象上调用,所以速度快得多

4、插入html代码的时候,浏览器原生的innterHTML()方法比jQuery对象的html()更快

尽量少生成jQuery对象

每当使用一次选择器(比如$('#id')),就会生成一个jQuery对象。jQuery对象是一个很庞大的对象,带有很多属性和方法,会占用不少资源。所以,尽量少生成jQuery对象

举例来说,许多jQuery方法都有两个版本,一个是供jQuery对象使用的版本,另一个是供jQuery函数使用的版本。下面两个例子,都是取出一个元素的文本,使用的都是text()方法

既可以使用针对jQuery对象的版本:

var $text = $("#text");
var $ts = $text.text();
登入後複製

也可以使用针对jQuery函数的版本:

var $text = $("#text");
var $ts = $.text($text);
登入後複製

由于后一种针对jQuery函数的版本不通过jQuery对象操作,所以相对开销较小,速度比较快

选择作用域链最短的方法

严格地说,这一条原则对所有Javascript编程都适用,而不仅仅针对jQuery

我们知道,Javascript的变量采用链式作用域。读取变量的时候,先在当前作用域寻找该变量,如果找不到,就前往上一层的作用域寻找该变量。这样的设计,使得读取局部变量比读取全局变量快得多

请看下面两段代码,第一段代码是读取全局变量:

var a = 0;
  function x(){
    a += 1;
  }
登入後複製

第二段代码是读取局部变量:

function y(){
    var a = 0;
    a += 1;
  }
登入後複製

第二段代码读取变量a的时候,不用前往上一层作用域,所以要比第一段代码快五六倍

同理,在调用对象方法的时候,closure模式要比prototype模式更快

prototype模式:

var X = function(name){ this.name = name; }
X.prototype.get_name = function() { return this.name; };
登入後複製

closure模式:

var Y = function(name) {
    var y = { name: name };
    return { 'get_name': function() { return y.name; } };
  };
登入後複製

同样是get_name()方法,closure模式更快

使用Pub/Sub模式管理事件

当发生某个事件后,如果要连续执行多个操作,最好不要写成下面这样:

function doSomthing{
    doSomethingElse();
    doOneMoreThing();
  }
登入後複製

而要改用事件触发的形式:

function doSomething{
    $.trigger("DO_SOMETHING_DONE");
  }
  $(document).on("DO_SOMETHING_DONE", function(){
    doSomethingElse(); 
  });
登入後複製

还可以考虑使用deferred对象

function doSomething(){
    var dfd = new $.Deferred();
    //Do something async, then... 
    //dfd.resolve();
    return dfd.promise();
  }
  function doSomethingElse(){
    $.when(doSomething()).then(//The next thing);
  }
登入後複製

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在微信小程序中如何使用switch开关选择器

在JavaScript中如何计算多边形质心

在Angular19中有关自定义表单控件使用

以上是在jQuery中有關程式碼優化的詳細說明的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

熱門話題

Java教學
1672
14
CakePHP 教程
1428
52
Laravel 教程
1332
25
PHP教程
1277
29
C# 教程
1257
24
jQuery引用方法詳解:快速上手指南 jQuery引用方法詳解:快速上手指南 Feb 27, 2024 pm 06:45 PM

jQuery引用方法詳解:快速上手指南jQuery是一個受歡迎的JavaScript庫,被廣泛用於網站開發中,它簡化了JavaScript編程,並為開發者提供了豐富的功能和特性。本文將詳細介紹jQuery的引用方法,並提供具體的程式碼範例,幫助讀者快速上手。引入jQuery首先,我們需要在HTML檔案中引入jQuery函式庫。可以透過CDN連結的方式引入,也可以下載

jQuery中如何使用PUT請求方式? jQuery中如何使用PUT請求方式? Feb 28, 2024 pm 03:12 PM

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

jQuery小技巧:快速修改頁面所有a標籤的文本 jQuery小技巧:快速修改頁面所有a標籤的文本 Feb 28, 2024 pm 09:06 PM

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

使用jQuery修改所有a標籤的文字內容 使用jQuery修改所有a標籤的文字內容 Feb 28, 2024 pm 05:42 PM

標題:使用jQuery修改所有a標籤的文字內容jQuery是一款受歡迎的JavaScript庫,被廣泛用於處理DOM操作。在網頁開發中,經常會遇到需要修改頁面上連結標籤(a標籤)的文字內容的需求。本文將介紹如何使用jQuery來實現這個目標,並提供具體的程式碼範例。首先,我們需要在頁面中引入jQuery庫。在HTML檔案中加入以下程式碼:

jQuery如何移除元素的height屬性? jQuery如何移除元素的height屬性? Feb 28, 2024 am 08:39 AM

jQuery如何移除元素的height屬性?在前端開發中,經常會遇到需要操作元素的高度屬性的需求。有時候,我們可能需要動態改變元素的高度,而有時候又需要移除元素的高度屬性。本文將介紹如何使用jQuery來移除元素的高度屬性,並提供具體的程式碼範例。在使用jQuery操作高度屬性之前,我們首先需要了解CSS中的height屬性。 height屬性用於設定元素的高度

了解jQuery中eq的作用及應用場景 了解jQuery中eq的作用及應用場景 Feb 28, 2024 pm 01:15 PM

jQuery是一種流行的JavaScript庫,被廣泛用於處理網頁中的DOM操作和事件處理。在jQuery中,eq()方法是用來選擇指定索引位置的元素的方法,具體使用方法和應用場景如下。在jQuery中,eq()方法選擇指定索引位置的元素。索引位置從0開始計數,即第一個元素的索引是0,第二個元素的索引是1,依此類推。 eq()方法的語法如下:$("s

程式效能優化有哪些常見的方法? 程式效能優化有哪些常見的方法? May 09, 2024 am 09:57 AM

程式效能最佳化方法包括:演算法最佳化:選擇時間複雜度較低的演算法,減少迴圈和條件語句。資料結構選擇:根據資料存取模式選擇合適的資料結構,例如查找樹和雜湊表。記憶體最佳化:避免建立不必要對象,釋放不再使用的內存,使用記憶體池技術。執行緒優化:識別可並行化任務,優化執行緒同步機制。資料庫最佳化:建立索引加快資料檢索,優化查詢語句,使用快取或NoSQL資料庫提升效能。

使用jQuery為表格新增一行的方法介紹 使用jQuery為表格新增一行的方法介紹 Feb 29, 2024 am 08:12 AM

jQuery是一個受歡迎的JavaScript函式庫,廣泛用於網頁開發。在網頁開發過程中,經常需要透過JavaScript動態地在表格中新增一行。本文將介紹如何使用jQuery為表格新增一行,並提供具體的程式碼範例。首先,我們需要在HTML頁面中引入jQuery函式庫。可以透過以下程式碼在標籤中引入jQuery庫:

See all articles