国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
Yahoo!團(tuán)隊實踐分享:網(wǎng)站性能優(yōu)化的34條黃金守則(三)—JavaScript和CSS
除此之外,JavaScript和CSS也是我們頁面中經(jīng)常用到的內(nèi)容,對它們的優(yōu)化也提高網(wǎng)站性能的重要方面:
CSS:
  1. 把樣式表置于頂部
  2. 避免使用CSS表達(dá)式(Expression)
  3. 使用外部JavaScript和CSS
  4. 削減JavaScript和CSS
  5. 用<link>代替@import
  6. 避免使用濾鏡

JavaScript

  1. 把腳本置于頁面底部
  2. 使用外部JavaScript和CSS
  3. 削減JavaScript和CSS
  4. 剔除重復(fù)腳本
  5. 減少DOM訪問
  6. 開發(fā)智能事件處理程序


17、把樣式表置于頂部
      在研究Yahoo!的性能表現(xiàn)時,我們發(fā)現(xiàn)把樣式表放到文檔的<head />內(nèi)部似乎會加快頁面的下載速度。這是因為把樣式表放到<head />內(nèi)會使頁面有步驟的加載顯示。
      注重性能的前端服務(wù)器往往希望頁面有秩序地加載。同時,我們也希望瀏覽器把已經(jīng)接收到內(nèi)容盡可能顯示出來。這對于擁有較多內(nèi)容的頁面和網(wǎng)速較慢的用戶來說特別重要。向用戶返回可視化的反饋,比如進(jìn)程指針,已經(jīng)有了較好的研究并形成了正式文檔。在我們的研究中HTML頁面就是進(jìn)程指針。當(dāng)瀏覽器有序地加載文件頭、導(dǎo)航欄、頂部的logo等對于等待頁面加載的用戶來說都可以作為可視化的反饋。這從整體上改善了用戶體驗。
      把樣式表放在文檔底部的問題是在包括Internet Explorer在內(nèi)的很多瀏覽器中這會中止內(nèi)容的有序呈現(xiàn)。瀏覽器中止呈現(xiàn)是為了避免樣式改變引起的頁面元素重繪。用戶不得不面對一個空白頁面。
      HTML規(guī)范清楚指出樣式表要放包含在頁面的<head />區(qū)域內(nèi):“和<a />不同,<link/>只能出現(xiàn)在文檔的<head/>區(qū)域內(nèi),盡管它可以多次使用它”。無論是引起白屏還是出現(xiàn)沒有樣式化的內(nèi)容都不值得去嘗試。最好的方案就是按照HTML規(guī)范在文檔<head />內(nèi)加載你的樣式表。

     一個減少CSS表達(dá)式計算次數(shù)的方法就是使用一次性的表達(dá)式,它在第一次運行時將結(jié)果賦給指定的樣式屬性,并用這個屬性來代替CSS表達(dá)式。如果樣式屬性必須在頁面周期內(nèi)動態(tài)地改變,使用事件句柄來代替CSS表達(dá)式是一個可行辦法。如果必須使用CSS表達(dá)式,一定要記住它們要計算成千上萬次并且可能會對你頁面的性能產(chǎn)生影響。

19、使用外部JavaScript和CSS
      很多性能規(guī)則都是關(guān)于如何處理外部文件的。但是,在你采取這些措施前你可能會問到一個更基本的問題:JavaScript和CSS是應(yīng)該放在外部文件中呢還是把它們放在頁面本身之內(nèi)呢?
     在實際應(yīng)用中使用外部文件可以提高頁面速度,因為JavaScript和CSS文件都能在瀏覽器中產(chǎn)生緩存。內(nèi)置在HTML文檔中的JavaScript和CSS則會在每次請求中隨HTML文檔重新下載。這雖然減少了HTTP請求的次數(shù),卻增加了HTML文檔的大小。從另一方面來說,如果外部文件中的JavaScript和CSS被瀏覽器緩存,在沒有增加HTTP請求次數(shù)的同時可以減少HTML文檔的大小。
     關(guān)鍵問題是,外部JavaScript和CSS文件緩存的頻率和請求HTML文檔的次數(shù)有關(guān)。雖然有一定的難度,但是仍然有一些指標(biāo)可以一測量它。如果一個會話中用戶會瀏覽你網(wǎng)站中的多個頁面,并且這些頁面中會重復(fù)使用相同的腳本和樣式表,緩存外部文件就會帶來更大的益處。
      許多網(wǎng)站沒有功能建立這些指標(biāo)。對于這些網(wǎng)站來說,最好的堅決方法就是把JavaScript和CSS作為外部文件引用。比較適合使用內(nèi)置代碼的例外就是網(wǎng)站的主頁,如Yahoo!主頁My Yahoo!。主頁在一次會話中擁有較少(可能只有一次)的瀏覽量,你可以發(fā)現(xiàn)內(nèi)置JavaScript和CSS對于終端用戶來說會加快響應(yīng)時 間。
     對于擁有較大瀏覽量的首頁來說,有一種技術(shù)可以平衡內(nèi)置代碼帶來的HTTP請求減少與通過使用外部文件進(jìn)行緩存帶來的好處。其中一個就是在首頁中內(nèi)置JavaScript和CSS,但是在頁面下載完成后動態(tài)下載外部文件,在子頁面中使用到這些文件時,它們已經(jīng)緩存到瀏覽器了。

20、削減JavaScript和CSS
     精簡是指從去除代碼不必要的字符減少文件大小從而節(jié)省下載時間。消減代碼時,所有的注釋、不需要的空白字符(空格、換行、tab縮進(jìn))等都要去掉。在JavaScript中,由于需要下載的文件體積變小了從而節(jié)省了響應(yīng)時間。精簡JavaScript中目前用到的最廣泛的兩個工具是JSMinYUI Compressor。YUI Compressor還可用于精簡CSS。
     混淆是另外一種可用于源代碼優(yōu)化的方法。這種方法要比精簡復(fù)雜一些并且在混淆的過程更易產(chǎn)生問題。在對美國前10大網(wǎng)站的調(diào)查中發(fā)現(xiàn),精簡也可以縮小原來代碼體積的21%,而混淆可以達(dá)到25%。盡管混淆法可以更好地縮減代碼,但是對于JavaScript來說精簡的風(fēng)險更小。
     除消減外部的腳本和樣式表文件外,<script>和<style>代碼塊也可以并且應(yīng)該進(jìn)行消減。即使你用Gzip壓縮過腳本和樣式表,精簡這些文件仍然可以節(jié)省5%以上的空間。由于JavaScript和CSS的功能和體積的增加,消減代碼將會獲得益處。

21、用<link>代替@import
      前面的最佳實現(xiàn)中提到CSS應(yīng)該放置在頂端以利于有序加載呈現(xiàn)。
      在IE中,頁面底部@import和使用<link>作用是一樣的,因此最好不要使用它。

22、避免使用濾鏡
     IE獨有屬性AlphaImageLoader用于修正7.0以下版本中顯示PNG圖片的半透明效果。這個濾鏡的問題在于瀏覽器加載圖片時它會終止內(nèi)容的呈現(xiàn)并且凍結(jié)瀏覽器。在每一個元素(不僅僅是圖片)它都會運算一次,增加了內(nèi)存開支,因此它的問題是多方面的。
      完全避免使用AlphaImageLoader的最好方法就是使用PNG8格式來代替,這種格式能在IE中很好地工作。如果你確實需要使用AlphaImageLoader,請使用下劃線_filter又使之對IE7以上版本的用戶無效。

23、把腳本置于頁面底部
      腳本帶來的問題就是它阻止了頁面的平行下載。HTTP/1.1 規(guī)范建議,瀏覽器每個主機(jī)名的并行下載內(nèi)容不超過兩個。如果你的圖片放在多個主機(jī)名上,你可以在每個并行下載中同時下載2個以上的文件。但是當(dāng)下載腳本時,瀏覽器就不會同時下載其它文件了,即便是主機(jī)名不相同。
      在某些情況下把腳本移到頁面底部可能不太容易。比如說,如果腳本中使用了document.write來插入頁面內(nèi)容,它就不能被往下移動了。這里可能還會有作用域的問題。很多情況下,都會遇到這方面的問題。
     一個經(jīng)常用到的替代方法就是使用延遲腳本。DEFER屬性表明腳本中沒有包含document.write,它告訴瀏覽器繼續(xù)顯示。不幸的是,F(xiàn)irefox并不支持DEFER屬性。在InternetExplorer中,腳本可能會被延遲但效果也不會像我們所期望的那樣。如果腳本可以被延遲,那么它就可以移到頁面的底部。這會讓你的頁面加載的快一點。

24、剔除重復(fù)腳本
     在同一個頁面中重復(fù)引用JavaScript文件會影響頁面的性能。你可能會認(rèn)為這種情況并不多見。對于美國前10大網(wǎng)站的調(diào)查顯示其中有兩家存在重復(fù)引用腳本的情況。有兩種主要因素導(dǎo)致一個腳本被重復(fù)引用的奇怪現(xiàn)象發(fā)生:團(tuán)隊規(guī)模和腳本數(shù)量。如果真的存在這種情況,重復(fù)腳本會引起不必要的HTTP請求和無用的JavaScript運算,這降低了網(wǎng)站性能。
      在InternetExplorer中會產(chǎn)生不必要的HTTP請求,而在Firefox卻不會。在InternetExplorer中,如果一個腳本被引用兩次而且它又不可緩存,它就會在頁面加載過程中產(chǎn)生兩次HTTP請求。即時腳本可以緩存,當(dāng)用戶重載頁面時也會產(chǎn)生額外的HTTP請求。
      除增加額外的HTTP請求外,多次運算腳本也會浪費時間。在Internet Explorer和Firefox中不管腳本是否可緩存,它們都存在重復(fù)運算JavaScript的問題。
      一個避免偶爾發(fā)生的兩次引用同一腳本的方法是在模板中使用腳本管理模塊引用腳本。在HTML頁面中使用<script />標(biāo)簽引用腳本的最常見方法就是:
      <script type="text/javascript" src="menu_1.0.17.js"></script>
在PHP中可以通過創(chuàng)建名為insertScript的方法來替代:
      <?php insertScript("menu.js") ?>
為了防止多次重復(fù)引用腳本,這個方法中還應(yīng)該使用其它機(jī)制來處理腳本,如檢查所屬目錄和為腳本文件名中增加版本號以用于Expire文件頭等。

25、減少DOM訪問
      使用JavaScript訪問DOM元素比較慢,因此為了獲得更多的應(yīng)該頁面,應(yīng)該做到:

  • 緩存已經(jīng)訪問過的有關(guān)元素
  • 線下更新完節(jié)點之后再將它們添加到文檔樹中
  • 避免使用JavaScript來修改頁面布局

      有關(guān)此方面的更多信息請查看Julien Lecomte在YUI專題中的文章“高性能Ajax應(yīng)該程序”。

26、開發(fā)智能事件處理程序
     有時候我們會感覺到頁面反應(yīng)遲鈍,這是因為DOM樹元素中附加了過多的事件句柄并且些事件句病被頻繁地觸發(fā)。這就是為什么說使用eventdelegation(事件代理)是一種好方法了。如果你在一個div中有10個按鈕,你只需要在div上附加一次事件句柄就可以了,而不用去為每一個按鈕增加一個句柄。事件冒泡時你可以捕捉到事件并判斷出是哪個事件發(fā)出的。
      你同樣也不用為了操作DOM樹而等待onload事件的發(fā)生。你需要做的就是等待樹結(jié)構(gòu)中你要訪問的元素出現(xiàn)。你也不用等待所有圖像都加載完畢。
      你可能會希望用DOMContentLoaded事件來代替onload,但是在所有瀏覽器都支持它之前你可使用YUI 事件應(yīng)用程序中的onAvailable方法。
      有關(guān)此方面的更多信息請查看Julien Lecomte在YUI專題中的文章“高性能Ajax應(yīng)該程序”。


本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
優(yōu)化網(wǎng)站性能提高網(wǎng)站訪問速度
五招加速網(wǎng)頁響應(yīng)時間-制作技巧-網(wǎng)頁制作大寶庫
怎樣提高網(wǎng)站訪問速度縮短網(wǎng)頁加載時間
性能優(yōu)化之html、css、js三者的加載順序
高性能網(wǎng)站建設(shè)的14個原則
【原】雅虎前端優(yōu)化的35條軍規(guī)
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服