首頁 web前端 js教程 7個jQuery最佳實踐_jquery

7個jQuery最佳實踐_jquery

May 16, 2016 pm 03:20 PM
jquery 最佳實踐

隨著富網絡應用(rich web applications)數量的增長,以及用戶對快速交互響應的高期望,開發者開始使用JavaScript庫來快速高效的完成一些重複性的工作。這其中最受歡迎的JavaScript函式庫就是jQuery。但jQuery的大量應用卻帶來了另一個問題:在使用JavaScript函式庫的時候,有哪些最佳實踐,又有哪些不好的實踐呢?

背景

在這篇文章中,我會給大家介紹在編寫、調試和審查JavaScript程式碼的時候一些好的實踐(至少我是這麼認為的)。事實上,我選擇了其中7個最常見的場景。

1、使用CDN及其回退位址(fallback)

CDN代表內容傳遞網路(Content Delivery Network),是快取了JavaScript檔案的伺服器。使用CDN之後,每當一個新用戶發起請求的時候,你的應用程式可以使用CDN緩存,而不用從你的伺服器上重新載入庫檔案。 Google、Microsoft和JQuery都提供CDN服務。

鑑於網路並不總是100%可靠,伺服器也可能因為一些原因宕機,你必須確保即使這些事情發生,你的應用程式依然能正常運作。這時候我們就要用到回退位址:當應用程式無法找到快取庫的時候,它就會回退回來,使用伺服器檔案。

Google CDN 是這樣的:

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"> </script>
登入後複製

Microsoft CDN是這樣的:

<script src="//ajax.aspnetcdn.com/ajax/jquery/jquery-1.9.0.min.js"> </script>
登入後複製

要注意的是,我們沒有指定URL協定為http而是使用的//。這是因為CDN伺服器支援http和https,如果你的網站擁有SSL認證,你無須修改就可以正常載入檔案。

另外,就像我之前提到的那樣,我們還需要一個回退位址,以防CDN伺服器出現問題。

<script>Window.JQuery || document.write(&lsquo;<script src=&rdquo;script/localsourceforjquery&rdquo;></script>&rsquo;)
登入後複製

當然,你也可以用Require來設定需要的jQuery,不過我覺得就這樣也不錯。

2、限制DOM互動

用JavaScript操作DOM樹是存在效能消耗的。 jQuery也一樣。所以,盡量減少與DOM的互動吧。當我幫助我一個同事提高數據顯示速度的時候,我看見他在一個循環裡面使用了選擇器。這簡直是效能殺手!他是這樣寫的:

containerDiv = $("#contentDiv");
for(var d =0; d < TotalActions; d++)
{
 containerDiv.append("<div><span class='brilliantRunner'>" + d + "</span></div>");
}
登入後複製

有什麼問題呢? 咋一看沒啥問題。而且我的同事也說這段程式碼跑得很歡樂!我真是嗶了狗狗了!當TotalActions小於50時,察覺不到任何問題;但是其達到25000的時候,速度便降低了很多,原因(我也是google到的)就是DOM交互放到了循環當中。

對於這個功能,(多次嘗試失敗之後)我將循環中的直接DOM交互替換成了一個數組的push操作,然後用一個空字符串作為分隔符將數組連接(join)起來。最後,程序當然變得更加流暢和有效率了。

var myContent=[];
for(var d = 0; d < TotalActions; d++)
{
 myContent.push("<div><span class='brilliantRunner'>" + d + "</span></div>");
}
containerDiv.html(myContent.join(""));
登入後複製

3、快取

jQuery最重要也是最有特色的地方,就是它的選擇器以及在DOM樹中尋找HTML元素的方式。但是,我多次看到,有些開發者在同一個函數中,多次呼叫相同的選擇器,例如 $(“#divid”)。儘管jQuery選擇元素非常快,但也不要每次都去找相同的元素。所以,你可以像這樣快取的你元素:

var $divId = $("#divId")
登入後複製

然後在接下來的程式碼中,就可以用$divId了。

對於下面的程式碼:

var thefunction = function()
{
 $("#mydiv").ToggleClass("zclass");
 $("#mydiv").fadeOut(800);
}

var thefunction2 = function()
{
 $("#mydiv").addAttr("name");
 $("#mydiv").fadeIn(400);
}

登入後複製

我們可以對它做這樣的修改,並且使用鍊式語法,使其看起來更加漂亮:

var mydiv =$("#mydiv");
var thefunction = function()
{
 mydiv.ToggleClass("zclass").fadeOut(800);
}

var thefunction2 = function()
{
 mydiv.addAttr("name").fadeIn(400);
}

登入後複製

但是話又說回來,你也不用每次把所有東西都緩存起來。看下面的範例:

$("#link").click(function()
{
  $(this).addClass("gored");
}
登入後複製

在这里,我既没有用 $(“#link”),或者将其缓存起来,而是使用的$(this)。因为在这个例子中,我操作的对象就是这个链接本身。

4、find 和 filter

最近,在使用find()来获取jQuery对象结合的时候,我产生了一些困惑。然后我发现,这个操作可以替换为用filter()方法来实现。理解这两者的区别非常重要:

find: 将会从选定的元素开始,一直向下查找DOM树

filter: 是在jQuery集合当中查找
5、end()

当在jQuery集合中进行链式操作的时候,我有时候需要回到父对象去进行一些操作。比如你正在一个表格的第二行应用CSS,然后希望回到表格对象,对其添加一些样式。在你对行应用完样式之后,只要使用end()方法,你就会自动回到表格对象,然后随意的对其添加样式吧!

(译者注:find()、filter()和end()原文是大写,其实应该是小写)

6、对象字面量

当你通过链式语法来操作元素的CSS属性的时候,你可以使用对象字面量方式来提升性能。比如这段代码:

$("#myimg").attr("src", "thepath").attr("alt", "the alt text");
登入後複製

变成下面这样之后,不仅避免了操作DOM元素,而且还不用多次调用相关的设置方法:

$("#myimg").attr({"src": "thepath", "alt": "the alt text"});
登入後複製

7、善用CSS类

尽可能使用CSS类而不要写内联CSS代码。我想这一点就不需要举例说明了吧。

希望这篇文章能够帮助你编写更好的jQuery应用程序,真正的帮助到大家。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡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

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

熱工具

記事本++7.3.1

記事本++7.3.1

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

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

PHP中處理字串轉浮點數的最​​佳實踐 PHP中處理字串轉浮點數的最​​佳實踐 Mar 28, 2024 am 08:18 AM

在PHP中處理字串轉浮點數是開發過程中常見的需求,例如從資料庫讀取到的金額欄位是字串類型,需要轉換為浮點數進行數值計算。在這篇文章中,我們將介紹PHP中處理字串轉浮點數的最​​佳實踐,並給出具體的程式碼範例。首先,我們需要明確一點,PHP中的字串轉浮點數有兩種主要的方式:使用(float)型別轉換或使用(floatval)函數。下面我們將分別來介紹這兩

Golang中字符串拼接的最佳實踐是什麼? Golang中字符串拼接的最佳實踐是什麼? Mar 14, 2024 am 08:39 AM

Golang中字符串拼接的最佳实践是什么?在Golang中,字符串拼接是一种常见的操作,但是要考虑到效率和性能。在处理大量字符串拼接时,选择合适的方法可以显著提升程序的性能。下面将介绍几种Golang中字符串拼接的最佳实践,并附上具体的代码示例。使用strings包的Join函数在Golang中,使用strings包的Join函数是一种高效的字符串拼接方法。

探討在Go語言中縮排的最佳實踐 探討在Go語言中縮排的最佳實踐 Mar 21, 2024 pm 06:48 PM

在Go語言中,良好的縮排是程式碼可讀性的關鍵。在編寫程式碼時,統一的縮排風格能夠使程式碼更加清晰、易於理解。本文將探討在Go語言中縮排的最佳實踐,並提供具體的程式碼範例。使用空格而不是製表符在Go語言中,建議使用空格而不是製表符進行縮排。這樣可以避免不同編輯器中製表符寬度不一致所導致的排版問題。縮排的空格數Go語言官方建議使用4個空格作為縮排的空格數。這樣可以使程式碼在

golang框架有哪些最佳實踐 golang框架有哪些最佳實踐 Jun 01, 2024 am 10:30 AM

在使用Go框架時,最佳實踐包括:選擇輕量級框架,如Gin或Echo。遵循RESTful原則,使用標準HTTP動詞和格式。利用中間件簡化任務,如身份驗證和日誌記錄。正確處理錯誤,使用錯誤類型和有意義的訊息。編寫單元測試和整合測試,確保應用程式正常運作。

深入比較:Java框架與其他語言框架的最佳實踐 深入比較:Java框架與其他語言框架的最佳實踐 Jun 04, 2024 pm 07:51 PM

Java框架適用於跨平台、穩定性和可擴展性至關重要的專案。對於Java項目,SpringFramework用於依賴注入和麵向方面編程,最佳實踐包括使用SpringBean和SpringBeanFactory。 Hibernate用於物件關係映射,最佳實踐是使用HQL進行複雜查詢。 JakartaEE用於企業應用開發,最佳實踐是使用EJB進行分散式業務邏輯。

PHP最佳實踐:避免goto語句的替代方案探討 PHP最佳實踐:避免goto語句的替代方案探討 Mar 28, 2024 pm 04:57 PM

PHP最佳實踐:避免goto語句的替代方案探討在PHP程式設計中,goto語句是一種控制結構,它允許直接跳到程式中的另一個位置。雖然goto語句可以簡化程式碼結構和流程控制,但由於其使用容易導致程式碼混亂、可讀性降低以及除錯困難等問題,因此被廣泛認為是一種不良實踐。在實際開發中,為避免使用goto語句,我們需要尋找替代方法來實現相同的功能。本文將探討一些替代方案,

Laravel開發中.env檔的作用及最佳實踐 Laravel開發中.env檔的作用及最佳實踐 Mar 10, 2024 pm 03:03 PM

Laravel開發中.env文件的作用及最佳實踐在Laravel應用程式開發中,.env文件被認為是非常重要的文件之一。它承載著一些關鍵的配置訊息,例如資料庫連接資訊、應用程式環境、應用程式金鑰等。在本文中,我們將深入探討.env檔案的作用以及最佳實踐,並附上具體的程式碼範例。 1..env檔的作用首先,我們需要了解.env檔的作用。在一個Laravel應

Git 還是版本控制? PHP 專案管理中的關鍵區別 Git 還是版本控制? PHP 專案管理中的關鍵區別 Mar 10, 2024 pm 01:04 PM

版本控制:基礎版本控制是一種軟體開發實踐,允許團隊追蹤程式碼庫中的變更。它提供了一個中央儲存庫,其中包含專案文件的所有歷史版本。這使開發人員能夠輕鬆回滾錯誤,查看不同版本的差異,並協調對程式碼庫的並發變更。 Git:分散式版本控制系統git是一種分散式版本控制系統(DVCS),這表示每個開發人員的電腦都擁有整個程式碼庫的完整副本。這消除了對中心伺服器的依賴,提高了團隊的靈活性和協作能力。 Git允許開發人員建立和管理分支,追蹤程式碼庫的歷史,並與其他開發者共用變更。 Git與版本控制:關鍵區別分散式vs集

See all articles