国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

OneAPM大講堂 | 提高JavaScript性能的30個技巧

harryhappy / 1400人閱讀

摘要:技巧評估局部變量主要針對而言,由于局部變量的查找是從最特定作用域到最大作用域,且可以通過多個域層級,所以這種查找會導致查詢到通用的結果。

文章系國內領先的 ITOM 管理平臺供應商 OneAPM 編譯呈現。

您是網站管理員還是網頁開發人員?想創建超快速的網站嗎?

今天我們來看看 JavaScript,這項神奇而又復雜的技術。它使網站內容更加豐富,但常常出現的運行性能問題又降低了用戶的體驗。事實已經證明,最佳的終端用戶體驗能提升網站的轉換率、Google搜索排名以及訪問者的滿意度。高性能的JavaScript意味著會給您和您的公司帶來更多更好的業務。

下面我們介紹提高 JavaScript 性能的一些技巧。同樣地,這或許可以幫助網站管理員和網站開發人員創建快速的網站,并提供一流的用戶體驗。

技巧 #1 – 評估局部變量
(http://blogs.msdn.com/b/ie/ar...

主要針對IE而言,由于局部變量的查找是從最特定作用域到最大作用域,且可以通過多個域層級,所以這種查找會導致查詢到通用的結果。在定義函數作用域的時候,如果一個局部變量在之前沒有進行過var變量聲明, 那么此處一定要在變量名前加上var關鍵字以定義其當前的作用域和防止查詢,從而提高代碼的速度。

技巧 #2 – 創建代碼快捷方式以加速編碼
對于使用頻繁的有用代碼,可以通過為較長的代碼創建快捷方式來加快編碼過程,例如 document.getElementById。 通過創建一個快捷方式,編寫較長的腳本便不會耗時太久,并且可以節省整個過程的時間。

技巧 #3 – 在將元素片段添加到DOM之前對其實施操作
(http://www.jquery4u.com/dom-m...

在創建 DOM 的元素節點之前,請確保已經執行了所有的操作,以提高 JavaScript 的性能。 這樣就無需再摒棄 Prepend和 Append 的 jQuery APIs 了。

技巧 #4 – 使用Minification保存字節
(http://sixrevisions.com/web-d...

通過刪除字符(標簽,源代碼文檔,空格等)而不改變文件功能的方式減小 JavaScript 文檔。

有許多縮小工具可以用來完成這個過程,并且還可以將縮小復原。 縮小是從源代碼中刪除所有不必要的字符而不改變其功能的過程。

技巧 #5 – 除非必要,否則不要使用嵌套循環
減少不必要的循環,例如 for 和 while 循環,以保持 JavaScript 的線性,并避免需要遍歷數千個對象。無用的循環可能會導致瀏覽器處理代碼時更困難,從而減緩速度。

技巧 #6 – 緩存對象以提高性能
很多時候,會重復使用腳本來訪問某個對象。 將重復訪問的對象存儲在用戶定義的變量中,并且之后在引用該對象時使用此變量,可以立刻實現性能提升。

技巧 #7 – 使用.js文件來緩存腳本
(http://www.javascriptkit.com/...

使用這種技術可以實現性能提升,因為它允許瀏覽器只加載腳本一次,當頁面被重新加載或重新訪問時只需要從緩存中調用腳本即可。

技巧 #8 – 將JavaScript放置到頁面的底部
將腳本盡可能放在頁面底部的位置會加快渲染進度,同時也會增加下載并行度。 其結果是頁面看起來加載得更快了,并且在某些情況下,它也可以減少所需要的總的代碼量。

技巧 #9 – 使用jQuery作為框架
jQuery 用于 HTML 腳本編程,是一個易于使用的 JavaScript 庫,可以幫助任何網站實現加速。 jQuery 提供了大量可以快速使用的插件,即使是新手程序員也不成問題。

技巧 #10 – 使用Gzip壓縮文件
(http://devmoose.com/coding/10...

使用 GZip 可以明顯地降低 JavaScript 文件的大小,節省帶寬,并加快響應時間。 有時 JavaScript 文件非常大,如果沒有經過壓縮,它可能會造成網站癱瘓。較小的文件能提供更快、更令人滿意的網頁體驗。

技巧 #11 – 不要使用With關鍵字
(http://blogs.msdn.com/b/ie/ar...

“With”這個關鍵詞被認為是害群之馬,因為它本身存在一些讓人倍感沮喪的缺陷。雖然有了它使用局部屬性的過程會變得更加簡單,但當在其他作用域中查找變量時,使用With會增大代價。

技巧 #12 – 盡量減少對HTTP的請求
(http://www.websiteoptimizatio...

通過結合外部文件和直接在 XHTML 頁面中嵌入 JavaScript 來盡量減少對 HTTP 返回頁面的請求。 每一個特定的 HTTP 請求傳輸至服務器端都會導致大量的時延。

技巧 #13 – 實現事件代理
使用事件代理將會使利用單個事件處理程序來為整個頁面管理某種事件類型變得更加容易。 如果不使用事件代理,大型的 Web 應用程序可能會由于過多的事件處理程序而停止工作。 實現事件代理的好處包括: 需要管理的功能更少,代碼和 DOM 之間的聯系更少,進程所需的內存更少。

技巧 #14 – 不要重復使用相同的腳本
(http://www.abhishekbharadwaj....

重復的腳本對性能會造成顯著的影響。重復的腳本會創建不需要的HTTP請求,尤其是在IE瀏覽器中。在HTML頁面中使用腳本標簽,可以幫助避免意外地生成重復的腳本。

技巧 #15 – 移除雙美元符號$$
(http://www.mellowmorning.com/...

當考慮提升網站的速度時,使用雙美元符號$$并不是必要的選擇。

技巧 #16 – 創建變量引用
(http://mondaybynoon.com/2009/...

當需要重復使用某個節點時,最好為該節點定義一個變量,使用節點時對變量進行引用,而不是反復來回操作。針對少量這樣的節點,也許這并不能顯著地提升性能,但是在節點數量很大時,這種方法就可以帶來明顯的影響。

技巧 #17 – 提高Object Detection的速度
(http://dean.edwards.name/webl...

一種更有效的使用 Object Detection 的方法是使用基于對象檢測而動態創建的代碼,而不是在函數內部去執行對象檢測。

技巧 #18 – 編寫有效的循環
(http://robertnyman.com/2008/0...

根據瀏覽器的不同,不同的循環實現方法也會對網站的性能產生很大的影響。 編寫不正確的循環可能會降低那些具有大訪問量的頁面的響應速度,或者導致同時運行多個循環。

技巧 #19 – 縮短作用域鏈
全局作用域通常較慢,因為每次執行函數的時候,它會引發創建一個臨時的調用作用域,JavaScript 會在作用域鏈中搜索第一個對象,如果找不到該變量,則會遍歷鏈直到搜索到全局對象。

技巧 #20 – 對NodeLists直接索引
NodeLists 是動態的,會占用大量的內存,因為當底層的文檔對象更改時它們也會被更新。 直接對列表進行索引會速度更快,因為此時瀏覽器不需要創建節點列表對象。

技巧 #21 – 不要使用‘eval’
雖然“eval”函數是運行任何代碼的好方法,但是在實際運行時,傳遞給 eval 函數的每個字符串都需要進行解析和執行。 每次調用eval函數的時候,都會引入這些時間開銷。

技巧 #22 – 使用函數內聯
(https://dl.acm.org/citation.c...

函數內聯有助于減少函數調用的成本,并用被調用的函數體替換函數調用。 在 JavaScript 中執行函數調用是一個高成本的操作,因為需要執行幾個準備步驟:為參數分配空間,復制參數以及解析函數名稱。

技巧 #23 – 實現 Common Sub-expression Elimination (CSE)
(http://sunilkumarn.wordpress....

Common Sub-expression Elimination (CSE)是一種以性能為目標的編譯器優化技術,用于搜索相同的表達式對象,并用保存著計算值的單個變量替換它們。可以認為,對通用子表達式使用單個的局部變量總是比保持代碼不變具有更快的速度。

技巧 #24 – 離線構建DOM節點以及所有子節點
當向站點添加復雜的內容(例如表格)時,通過離線的方式添加復雜的子樹可以提升性能。

技巧 #25 – 盡量不要使用全局變量
由于腳本引擎需要搜索作用域,所以當從函數內部或其他作用域內引用全局變量時,如果局部作用域丟失,全局變量將被銷毀。如果全局作用域中的變量并不一直存在于腳本的生命周期,則可以提升性能。

技巧 #26 – 使用原始的函數操作而不使用函數調用
通過使用等效的原函數而非函數調用,可以在對性能有關鍵影響的循環和函數中實現速度提升。

技巧 #27 – 不要一直保留對其他文檔的引用
(http://dev.opera.com/articles...

當腳本結束后不再保留對其他文檔的引用可以實現更快的性能。因為對其他文檔中的對象進行的任何引用不會被保存在整個 DOM 樹中,并且腳本環境也不會一直保留在內存中。 因此文檔本身不用再被加載。

技巧 #28 – 使用XMLHttpRequest
(http://dev.opera.com/articles...

XMLHttpRequest 有助于減少來自服務器端的內容數量,并且避免在頁面加載的間隙銷毀和重新創建腳本環境對性能造成的影響。一定要確保支持 XMLHttpRequest,否則可能會導致問題和混淆。

技巧 #29 – 避免使用try-catch-finally結構
(http://dev.opera.com/articles...

每當執行 catch 子句時,捕獲的異常對象被分配給一個變量,“try-catch-finally”會在運行時在當前作用域中創建一個新變量。 許多瀏覽器不能有效地處理這個過程,因為變量是在運行時被創建和銷毀的。避免使用它!

技巧 #30 – 不要誤用 for-in
(http://dev.opera.com/articles...

由于“for-in”循環需要腳本引擎構建包含所有可枚舉屬性的列表,因此 for 循環內的代碼是不會修改這個列表的。 在 for 循環內部,預先計算出列表的長度并賦給變量 len,然后進行迭代。

后續我們還會發布有關性能管理的系列帖子...敬請關注!

Browser Insight 是一個基于真實用戶的 Web 前端性能監控平臺,能夠幫大家定位網站性能瓶頸,網站加速效果可視化;支持瀏覽器、微信、App 瀏覽 HTML 和 HTML5 頁面。想閱讀更多技術文章,請訪問 OneAPM 官方技術博客。
來源:http://blog.oneapm.com/apm-te...

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/92557.html

相關文章

  • OneAPM講堂 | 誰更快?JavaScript 框架性能評測

    摘要:表格底部的減速幾何平均是一項總的性能指標,從左至右,依次表明了各個框架的評級。最左端是,表示無框架的實現,做為一個參考點。和都是顯著偏慢的框架,兩者給出的性能數據也相差無幾。 文章系國內領先的 ITOM 管理平臺供應商 OneAPM 編譯呈現。 網頁性能是一個豐富且又復雜的話題。在本帖中,我們會將討論的范圍局限在前端 JavaScript 框架上,探究相對于另外一種框架而言,使用當前的...

    BDEEFE 評論0 收藏0
  • 2016 年開發者應該掌握 Postgres 技巧

    摘要:近日,正式發布了版本,該版本進行了大量的修復和功能改進。事實上,開發者獲得的所有標準會使它更加強大一個最好的例子是來自近年來的索引,它給提供了極大的性能提升。在最新發布的版本中,在中的輸出也更具可讀性。 【編者按】作為一款開源的對象—關系數據庫,Postgres 一直得到許多開發者喜愛。近日,Postgres 正式發布了9.5版本,該版本進行了大量的修復和功能改進。而本文將分享10個 ...

    HitenDev 評論0 收藏0
  • 影響網頁渲染關鍵

    摘要:最優化渲染路徑,實際上只要聚焦三件事情最小化關鍵資源的數量最小化關鍵字節數最小化關鍵路徑的長度理解頁面加載速度的測量辦法當百度談論頁面加載速度時,他們并不是指加載一個網頁的總時間。 張超 — MAY 21, 2015 經常有站長、開發者、運維疑惑:為什么我們的后臺服務器很快,但是用戶要看網頁里面的內容卻需要很長時間?我們在上一篇文章《怪獸大作戰: 解析網站打開慢的原因》中簡單介紹了影...

    weknow619 評論0 收藏0
  • 人分享--web前端學習資源分享

    摘要:前言月份開始出沒社區,現在差不多月了,按照工作的說法,就是差不多過了三個月的試用期,準備轉正了一般來說,差不多到了轉正的時候,會進行總結或者分享會議那么今天我就把看過的一些學習資源主要是博客,博文推薦分享給大家。 1.前言 6月份開始出沒社區,現在差不多9月了,按照工作的說法,就是差不多過了三個月的試用期,準備轉正了!一般來說,差不多到了轉正的時候,會進行總結或者分享會議!那么今天我就...

    sherlock221 評論0 收藏0

發表評論

0條評論

harryhappy

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<