中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > YUI Compressor壓縮JavaScript原理
CSS.JS文件發(fā)布機制的思考 回到列表 模擬兼容性的addDOMLoadEvent事件
 YUI Compressor壓縮JavaScript原理

作者:blank 時間: 2009-08-03 文檔類型:原創(chuàng) 來自:藍色理想

YUI Compressor 壓縮 JavaScript 的內(nèi)容包括:

  1. 移除注釋
  2. 移除額外的空格
  3. 細微優(yōu)化
  4. 標識符替換(Identifier Replacement)

YUI Compressor 包括哪些細微優(yōu)化呢?

  • object["property"] ,如果屬性名是合法的 JavaScript 標識符(注:合法的 JavaScript 標識符——由一個字母開頭,其后選擇性地加上一個或者多個字母、數(shù)字或下劃線)且不是保留字,將優(yōu)化為: object.property
  • {"property":123} ,如果屬性名是合法的 JavaScript 標識符且不是保留字,將優(yōu)化為 {property:123} (注:在對象字面量中,如果屬性名是一個合法的 JavaScript 標識符且不是保留字,并不強制要求用引號引住屬性名)。
  • 'abcd\'efgh',將優(yōu)化為 "abcd'efgh"。
  • "abcd" + "efgh",如果是字符串相連接,將優(yōu)化成 "abcdefgh"(注:所有在使用 YUI Compressor 的前提下,對于腳本中的字符串連接,使用連接符 “+” 的效率和可維護性最高)。

對于 JavaScript 最有效的壓縮優(yōu)化,當屬標識符替換。

比如:

(function(){
    function add(num1, num2) {
        return num1 + num2;
    }
})();

進行屬標識符替換后:

(function(){
    function A(C, B) {
        return C+ B;   
}
})();

再移除額外的空格,最終成了:

(function(){function A(C,B){return C+B;}})();

YUI Compressor 標識符替換僅替換函數(shù)名和變量名,那哪些不能被替代呢?

  1. 原始值:字符串、布爾值、數(shù)字、null 和 undefined。一般來說字符串占的空間最多,而非數(shù)字字面量其次(true、false,null,underfinded)。
  2. 全局變量:window、document、XMLHttpRequest等等。使用最多的就是 document、window。
  3. 屬性名,比如:foo.bar。占據(jù)的空間僅次于字符串,”.” 操作符無法被代替,且 a.b.c 更加費空間。
  4. 關(guān)鍵字。經(jīng)常被過度使用的關(guān)鍵字有:var、return。最好的優(yōu)化方法:一個函數(shù)僅出現(xiàn)一次 var 和 return 關(guān)鍵字。

對于原始值、全局變量、屬性名的優(yōu)化處理方式大致相同:任何字面量值、全局變量或者屬性名被使用超過 2 次(包括2次),都應(yīng)該用局部變量存儲代替。

但有部分情況下是禁止使用標識符替換的:

  1. 使用 eval() 函數(shù)。解決方法:不使用或者創(chuàng)建一個全局函數(shù)封裝 eval()。
  2. 使用 with 語句。解決方法:方法同上。
  3. JScript 的條件注釋。唯一解決的方法:不使用。

由于 YUI Compressor 是建立在 rhino interpreter 基礎(chǔ)上的,所以上述所有的優(yōu)化都是安全的。

擴展閱讀:
《Extreme JavaScript Compression With YUI Compressor》

原文:
http://www.planabc.net/2009/08/02/javascript-compression_with_yui_compressor/

本文鏈接:http://www.95time.cn/tech/web/2009/6923.asp 

出處:藍色理想
責任編輯:bluehearts

◎進入論壇網(wǎng)頁制作、WEB標準化版塊參加討論,我還想發(fā)表評論。

相關(guān)文章 更多相關(guān)鏈接
YUI Grids CSS 解讀
關(guān)于廣告點擊率的原理
網(wǎng)絡(luò)測試原理及分類
Java遠程通訊可選技術(shù)及原理
基于flash的360虛擬現(xiàn)實引擎實現(xiàn)
作者文章 更多作者文章
模擬兼容性的addDOMLoadEvent事件
JavaScript獲取事件對象的注意點
如何在 IE 中使用 HTML5 元素
JavaScript 實現(xiàn) Konami Code
影響reflow的因素及其優(yōu)化
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2