久久久精品一区ed2k-女人被男人叉到高潮的视频-中文字幕乱码一区久久麻豆樱花-俄罗斯熟妇真实视频

如何提高javascript和css網(wǎng)站前端的性能優(yōu)化-創(chuàng)新互聯(lián)

本篇文章為大家展示了如何提高javascript和css網(wǎng)站前端的性能優(yōu)化,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

專(zhuān)注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)神木免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了成百上千家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

CSS性能優(yōu)化

1、把樣式表置于頂部

現(xiàn)把樣式表放到文檔的< head />內(nèi)部似乎會(huì)加快頁(yè)面的下載速度。這是因?yàn)榘褬邮奖矸诺?lt; head />內(nèi)會(huì)使頁(yè)面有步驟的加載顯示。

注重性能的前端服務(wù)器往往希望頁(yè)面有秩序地加載。同時(shí),我們也希望瀏覽器把已經(jīng)接收到內(nèi)容盡可能顯示出來(lái)。這對(duì)于擁有較多內(nèi)容的頁(yè)面和網(wǎng)速較慢的用戶來(lái)說(shuō)特別重要。向用戶返回可視化的反饋,比如進(jìn)程指針,已經(jīng)有了較好的研究并形成了正式文檔。在我們的研究中HTML頁(yè)面就是進(jìn)程指針。當(dāng)瀏覽器有序地加載文件頭、導(dǎo)航欄、頂部的logo等對(duì)于等待頁(yè)面加載的用戶來(lái)說(shuō)都可以作為可視化的反饋。這從整體上改善了用戶體驗(yàn)。

把樣式表放在文檔底部的問(wèn)題是在包括Internet Explorer在內(nèi)的很多瀏覽器中這會(huì)中止內(nèi)容的有序呈現(xiàn)。瀏覽器中止呈現(xiàn)是為了避免樣式改變引起的頁(yè)面元素重繪。用戶不得不面對(duì)一個(gè)空白頁(yè)面。

HTML規(guī)范清 楚指出樣式表要放包含在頁(yè)面的< head />區(qū)域內(nèi):“和< a />不同,< link />只能出現(xiàn)在文檔的< head />區(qū)域內(nèi),盡管它可以多次使用它”。無(wú)論是引起白屏還是出現(xiàn)沒(méi)有樣式化的內(nèi)容都不值得去嘗試。好的方案就是按照HTML規(guī)范在文 檔< head />內(nèi)加載你的樣式表。

2、避免使用CSS表達(dá)式(Expression)

表達(dá)式的問(wèn)題就在于它的計(jì)算頻率要比我們想象的多。不僅僅是在頁(yè)面顯示和縮放時(shí),就是在頁(yè)面滾動(dòng)、乃至移動(dòng)鼠標(biāo)時(shí)都會(huì)要重新計(jì)算一次。給CSS表達(dá)式增加一個(gè)計(jì)數(shù)器可以跟蹤表達(dá)式的計(jì)算頻率。在頁(yè)面中隨便移動(dòng)鼠標(biāo)都可以輕松達(dá)到10000次以上的計(jì)算量。

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

3、使用外部JavaScript和CSS

很多性能規(guī)則都是關(guān)于如何處理外部文件的。但是,在你采取這些措施前你可能會(huì)問(wèn)到一個(gè)更基本的問(wèn)題:JavaScript和CSS是應(yīng)該放在外部文件中呢還是把它們放在頁(yè)面本身之內(nèi)呢?

在實(shí)際應(yīng)用中使用外部文件可以提高頁(yè)面速度,因?yàn)镴avaScript和CSS文件都能在瀏覽器中產(chǎn)生緩存。內(nèi)置在HTML文檔中的JavaScript 和CSS則會(huì)在每次請(qǐng)求中隨HTML文檔重新下載。這雖然減少了HTTP請(qǐng)求的次數(shù),卻增加了HTML文檔的大小。從另一方面來(lái)說(shuō),如果外部文件中的 JavaScript和CSS被瀏覽器緩存,在沒(méi)有增加HTTP請(qǐng)求次數(shù)的同時(shí)可以減少HTML文檔的大小。

關(guān)鍵問(wèn)題是,外部JavaScript和CSS文件緩存的頻率和請(qǐng)求HTML文檔的次數(shù)有關(guān)。雖然有一定的難度,但是仍然有一些指標(biāo)可以一測(cè)量它。如果一 個(gè)會(huì)話中用戶會(huì)瀏覽你網(wǎng)站中的多個(gè)頁(yè)面,并且這些頁(yè)面中會(huì)重復(fù)使用相同的腳本和樣式表,緩存外部文件就會(huì)帶來(lái)更大的益處。

對(duì)于擁有較大瀏覽量的首頁(yè)來(lái)說(shuō),有一種技術(shù)可以平衡內(nèi)置代碼帶來(lái)的HTTP請(qǐng)求減少與通過(guò)使用外部文件進(jìn)行緩存帶來(lái)的好處。其中一個(gè)就是在首頁(yè)中內(nèi)置 JavaScript和CSS,但是在頁(yè)面下載完成后動(dòng)態(tài)下載外部文件,在子頁(yè)面中使用到這些文件時(shí),它們已經(jīng)緩存到瀏覽器了。

4、削減JavaScript和CSS

精簡(jiǎn)是指從去除代碼不必要的字符減少文件大小從而節(jié)省下載時(shí)間。消減代碼時(shí),所有的注釋、不需要的空白字符(空格、換行、tab縮進(jìn))等都要去掉。在 JavaScript中,由于需要下載的文件體積變小了從而節(jié)省了響應(yīng)時(shí)間。精簡(jiǎn)JavaScript中目前用到的最廣泛的兩個(gè)工具是JSMin和YUI Compressor。YUI Compressor還可用于精簡(jiǎn)CSS。我之前的一篇文章關(guān)于前端部署的,ant+YUI Compressor 地址是:http://www.haorooms.com/post/ant_yuicom 小工具中也有ant的用法:http://www.haorooms.com/tools/ant_book/

混淆是另外一種可用于源代碼優(yōu)化的方法。這種方法要比精簡(jiǎn)復(fù)雜一些并且在混淆的過(guò)程更易產(chǎn)生問(wèn)題。在對(duì)美國(guó)前10大網(wǎng)站的調(diào)查中發(fā)現(xiàn),精簡(jiǎn)也可以縮小原來(lái) 代碼體積的21%,而混淆可以達(dá)到25%。盡管混淆法可以更好地縮減代碼,但是對(duì)于JavaScript來(lái)說(shuō)精簡(jiǎn)的風(fēng)險(xiǎn)更小。

除消減外部的腳本和樣式表文件外,< script>和< style>代碼塊也可以并且應(yīng)該進(jìn)行消減。即使你用Gzip壓縮過(guò)腳本 和樣式表,精簡(jiǎn)這些文件仍然可以節(jié)省5%以上的空間。由于JavaScript和CSS的功能和體積的增加,消減代碼將會(huì)獲得益處。

5、用代替@import

前面的很好實(shí)現(xiàn)中提到CSS應(yīng)該放置在頂端以利于有序加載呈現(xiàn)。

在IE中,頁(yè)面底部@import和使用< link>作用是一樣的,因此好不要使用它。

6、避免使用濾鏡

IE獨(dú)有屬性AlphaImageLoader用于修正7.0以下版本中顯示PNG圖片的半透明效果。這個(gè)濾鏡的問(wèn)題在于瀏覽器加載圖片時(shí)它會(huì)終止內(nèi)容的 呈現(xiàn)并且凍結(jié)瀏覽器。在每一個(gè)元素(不僅僅是圖片)它都會(huì)運(yùn)算一次,增加了內(nèi)存開(kāi)支,因此它的問(wèn)題是多方面的。

完全避免使用AlphaImageLoader的好方法就是使用PNG8格式來(lái)代替,這種格式能在IE中很好地工作。如果你確實(shí)需要使用AlphaImageLoader,請(qǐng)使用下劃線_filter又使之對(duì)IE7以上版本的用戶無(wú)效。

javascript性能優(yōu)化

1、把腳本置于頁(yè)面底部

腳本帶來(lái)的問(wèn)題就是它阻止了頁(yè)面的平行下載。HTTP/1.1 規(guī)范建議,瀏覽器每個(gè)主機(jī)名的并行下載內(nèi)容不超過(guò)兩個(gè)。如果你的圖片放在多個(gè)主機(jī)名上,你可以在每個(gè)并行下載中同時(shí)下載2個(gè)以上的文件。但是當(dāng)下載腳本時(shí),瀏覽器就不會(huì)同時(shí)下載其它文件了,即便是主機(jī)名不相同。

在某些情況下把腳本移到頁(yè)面底部可能不太容易。比如說(shuō),如果腳本中使用了document.write來(lái)插入頁(yè)面內(nèi)容,它就不能被往下移動(dòng)了。這里可能還會(huì)有作用域的問(wèn)題。很多情況下,都會(huì)遇到這方面的問(wèn)題。

一個(gè)經(jīng)常用到的替代方法就是使用延遲腳本。DEFER屬性表明腳本中沒(méi)有包含document.write,它告訴瀏覽器繼續(xù)顯示。不幸的 是,F(xiàn)irefox并不支持DEFER屬性。在Internet Explorer中,腳本可能會(huì)被延遲但效果也不會(huì)像我們所期望的那樣。如果腳本可以被延遲,那么它就可以移到頁(yè)面的底部。這會(huì)讓你的頁(yè)面加載的快一點(diǎn)。

2、使用外部JavaScript和CSS

同上,css中寫(xiě)了,我之前文章中列舉了一下cdn,可以調(diào)用外部的。

3、削減JavaScript和CSS

同上,css中寫(xiě)了

4、剔除重復(fù)腳本

在同一個(gè)頁(yè)面中重復(fù)引用JavaScript文件會(huì)影響頁(yè)面的性能。你可能會(huì)認(rèn)為這種情況并不多見(jiàn)。對(duì)于美國(guó)前10大網(wǎng)站的調(diào)查顯示其中有兩家存在重復(fù)引 用腳本的情況。有兩種主要因素導(dǎo)致一個(gè)腳本被重復(fù)引用的奇怪現(xiàn)象發(fā)生:團(tuán)隊(duì)規(guī)模和腳本數(shù)量。如果真的存在這種情況,重復(fù)腳本會(huì)引起不必要的HTTP請(qǐng)求和 無(wú)用的JavaScript運(yùn)算,這降低了網(wǎng)站性能。

在Internet Explorer中會(huì)產(chǎn)生不必要的HTTP請(qǐng)求,而在Firefox卻不會(huì)。在Internet Explorer中,如果一個(gè)腳本被引用兩次而且它又不可緩存,它就會(huì)在頁(yè)面加載過(guò)程中產(chǎn)生兩次HTTP請(qǐng)求。即時(shí)腳本可以緩存,當(dāng)用戶重載頁(yè)面時(shí)也會(huì)產(chǎn) 生額外的HTTP請(qǐng)求。

除增加額外的HTTP請(qǐng)求外,多次運(yùn)算腳本也會(huì)浪費(fèi)時(shí)間。在Internet Explorer和Firefox中不管腳本是否可緩存,它們都存在重復(fù)運(yùn)算JavaScript的問(wèn)題。

一個(gè)避免偶爾發(fā)生的兩次引用同一腳本的方法是在模板中使用腳本管理模塊引用腳本。在HTML頁(yè)面中使用< script />標(biāo)簽引用腳本的最常見(jiàn)方法就是:

<script type="text/javascript" src="menu_1.0.17.js"></script>

在PHP中可以通過(guò)創(chuàng)建名為insertScript的方法來(lái)替代:

<?php insertScript("menu.js") ?>

為了防止多次重復(fù)引用腳本,這個(gè)方法中還應(yīng)該使用其它機(jī)制來(lái)處理腳本,如檢查所屬目錄和為腳本文件名中增加版本號(hào)以用于Expire文件頭等。

5、減少DOM訪問(wèn)

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

緩存已經(jīng)訪問(wèn)過(guò)的有關(guān)元素

線下更新完節(jié)點(diǎn)之后再將它們添加到文檔樹(shù)中

避免使用JavaScript來(lái)修改頁(yè)面布局

6、開(kāi)發(fā)智能事件處理程序

有時(shí)候我們會(huì)感覺(jué)到頁(yè)面反應(yīng)遲鈍,這是因?yàn)镈OM樹(shù)元素中附加了過(guò)多的事件句柄并且些事件句病被頻繁地觸發(fā)。這就是為什么說(shuō)使用event delegation(事件代理)是一種好方法了。如果你在一個(gè)div中有10個(gè)按鈕,你只需要在div上附加一次事件句柄就可以了,而不用去為每一個(gè)按 鈕增加一個(gè)句柄。事件冒泡時(shí)你可以捕捉到事件并判斷出是哪個(gè)事件發(fā)出的。

你同樣也不用為了操作DOM樹(shù)而等待onload事件的發(fā)生。你需要做的就是等待樹(shù)結(jié)構(gòu)中你要訪問(wèn)的元素出現(xiàn)。你也不用等待所有圖像都加載完畢。

如何加載JS,JS應(yīng)該放在什么位置研究

外部JS的阻塞下載

所有瀏覽器在下載JS的時(shí)候,會(huì)阻止一切其他活動(dòng),比如其他資源的下載,內(nèi)容的呈現(xiàn)等等。至到JS下載、解析、執(zhí)行完畢后才開(kāi)始繼續(xù)并行下載其他資源并呈現(xiàn)內(nèi)容。

有人會(huì)問(wèn):為什么JS不能像CSS、image一樣并行下載了?這里需要簡(jiǎn)單介紹一下瀏覽器構(gòu)造頁(yè)面的原理, 當(dāng)瀏覽器從服務(wù)器接收到了HTML文檔,并把HTML在內(nèi)存中轉(zhuǎn)換成DOM樹(shù),在轉(zhuǎn)換的過(guò)程中如果發(fā)現(xiàn)某個(gè)節(jié)點(diǎn)(node)上引用了CSS或者 IMAGE,就會(huì)再發(fā)1個(gè)request去請(qǐng)求CSS或image,然后繼續(xù)執(zhí)行下面的轉(zhuǎn)換,而不需要等待request的返回,當(dāng)request返回 后,只需要把返回的內(nèi)容放入到DOM樹(shù)中對(duì)應(yīng)的位置就OK。但當(dāng)引用了JS的時(shí)候,瀏覽器發(fā)送1個(gè)js request就會(huì)一直等待該request的返回。因?yàn)闉g覽器需要1個(gè)穩(wěn)定的DOM樹(shù)結(jié)構(gòu),而JS中很有可能有代碼直接改變了DOM樹(shù)結(jié)構(gòu),比如使用 document.write 或 appendChild,甚至是直接使用的location.href進(jìn)行跳轉(zhuǎn),瀏覽器為了防止出現(xiàn)JS修改DOM樹(shù),需要重新構(gòu)建DOM樹(shù)的情況,所以 就會(huì)阻塞其他的下載和呈現(xiàn).

阻塞下載圖:下圖是訪問(wèn)blogjava首頁(yè)的時(shí)間瀑布圖,可以看出來(lái)開(kāi)始的2個(gè)image都是并行下載的,而后面的2個(gè)JS都是阻塞下載的(1個(gè)1個(gè)下載)。

如何提高javascript和css網(wǎng)站前端的性能優(yōu)化

嵌入JS的阻塞下載

嵌入JS是指直接寫(xiě)在HTML文檔中的JS代碼。上面說(shuō)了引用外部的JS會(huì)阻塞其后的資源下載和其后的內(nèi)容呈現(xiàn),哪嵌入的JS又會(huì)是怎樣阻塞的了,看下面的列2個(gè)代碼:

**代碼1:** 

< div >
         < ul >
             < li > blogjava </ li >
             < li > CSDN </ li >
             < li > haorooms博客 </ li >
             < li > ABC </ li >
             < li > AAA </ li >
         < ul >     
     </ div >
     < script  type ="text/javascript" >
        // 循環(huán)5秒鐘
         var  n  =  Number( new  Date());
     var  n2  =  Number( new  Date());
    while ((n2  -  n)  <  ( 6 * 1000 )){
       n2  =  Number( new  Date());
     }
     </ script >
   < div >
         < ul >
             < li > MSN </ li >
             < li > GOOGLE </ li >
             < li > YAHOO </ li >
         < ul >     
</ div >

運(yùn)行后,會(huì)發(fā)現(xiàn)代碼1中,在前5秒中頁(yè)面上是一篇空白,5秒中后頁(yè)面全部顯示。 代碼2中,前5秒中blogjava,csdn等先顯示出來(lái),5秒后MSN才顯示出來(lái)。
可以看出嵌入JS會(huì)阻塞所有內(nèi)容的呈現(xiàn),而外部JS只會(huì)阻塞其后內(nèi)容的顯示,2種方式都會(huì)阻塞其后資源的下載。

嵌入JS導(dǎo)致CSS阻塞加載的問(wèn)題

CSS怎么會(huì)阻塞加載了?CSS本來(lái)是可以并行下載的,在什么情況下會(huì)出現(xiàn)阻塞加載了(在測(cè)試觀察中,IE6下CSS都是阻塞加載,下面的測(cè)試在非IE6下進(jìn)行):

代碼1(為了效果,這里選擇了1個(gè)國(guó)外服務(wù)器的CSS):

< html  xmlns ="http://www.w3.org/1999/xhtml" >
         < head >
           < title > js test </ title >
           < meta  http-equiv ="Content-Type"  content ="text/html; charset=UTF-8"   />  
           < link  type ="text/css"  rel ="stylesheet"  href ="http://69.64.92.205/Css/Home3.css"   />
         </ head >
         < body >
             < img  src ="http://www.haorooms.com/images/logo.gif"   />< br  />
              < img  src ="http://www.haorooms.com/images/csdnindex_piclogo.gif"   />
         </ body >
</ html >

時(shí)間瀑布圖:

如何提高javascript和css網(wǎng)站前端的性能優(yōu)化

代碼2(只加了1個(gè)空的嵌入JS):

< head >
     < title > js test </ title >
     < meta  http-equiv ="Content-Type"  content ="text/html; charset=UTF-8"   />  
   < link  type ="text/css"  rel ="stylesheet"  href ="http://69.64.92.205/Css/Home3.css"   />
   < script  type ="text/javascript" >
         function  a(){}
   </ script >
</ head >
< body >
         < img  src ="http://www.haorooms.com/images/logo.gif"   />< br  />
         < img  src ="http://www.haorooms.com/images/csdnindex_piclogo.gif"   />
</ body >

時(shí)間瀑布圖:

如何提高javascript和css網(wǎng)站前端的性能優(yōu)化

從時(shí)間瀑布圖中可以看出,代碼2中,CSS和圖片并沒(méi)有并行下載,而是等待CSS下載完畢后才去并行下載后面的2個(gè)圖片,當(dāng)CSS后面跟著嵌入的JS的時(shí)候,該CSS就會(huì)出現(xiàn)阻塞后面資源下載的情況。
有人可能會(huì)問(wèn),這里為什么不說(shuō)說(shuō)嵌入的JS阻塞了后面的資源,而是說(shuō)CSS阻塞了? 想想我們現(xiàn)在用的是1個(gè)空函數(shù),解析這個(gè)空函數(shù)1ms就夠,而后面2個(gè)圖片是等CSS下載完1.3s后才開(kāi)始下載。大家還可以試試把嵌入JS放到CSS前 面,就不會(huì)出現(xiàn)阻塞的情況了。
根本原因:因?yàn)闉g覽器會(huì)維持html中css和js的順序,樣式表必須在嵌入的JS執(zhí)行前先加載、解析完。而嵌入的JS會(huì)阻塞后面的資源加載,所以就會(huì)出現(xiàn)上面CSS阻塞下載的情況。
嵌入JS應(yīng)該放在什么位置
1、放在底部,雖然放在底部照樣會(huì)阻塞所有呈現(xiàn),但不會(huì)阻塞資源下載。
2、如果嵌入JS放在head中,請(qǐng)把嵌入JS放在CSS前面。
3、使用defer
4、不要在嵌入的JS中調(diào)用運(yùn)行時(shí)間較長(zhǎng)的函數(shù),如果一定要用,可以用setTimeout來(lái)調(diào)用。

上述內(nèi)容就是如何提高javascript和css網(wǎng)站前端的性能優(yōu)化,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

新聞名稱(chēng):如何提高javascript和css網(wǎng)站前端的性能優(yōu)化-創(chuàng)新互聯(lián)
URL標(biāo)題:http://sd-ha.com/article32/dijppc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁(yè)設(shè)計(jì)公司、建站公司、品牌網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化、做網(wǎng)站、響應(yīng)式網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)