準(zhǔn)則(概述)

  • 減少 HTTP 請求

  • 使用CDN加速

  • 避免空的src或href屬性值

  • 增加過期頭

  • 啟GZIP壓縮

  • 把css文件放到頭部

  • 把javascript放到尾部

  • 避免使用css表達(dá)式

  • 刪除不使用的css語句

  • 對javascript、css代碼進(jìn)行壓縮

  • 減少重繪

減少HTTP請求

減少HTTP請求是上面性能準(zhǔn)則中最為顯著的一條,我們可以分為三個主要方面來討論

  • 使用并行連接
    開發(fā)人員往往只考慮服務(wù)器端對性能的影響卻疏忽了瀏覽器端的限制,比如有多少資源可以在同一時間加載。HTTP1.1協(xié)議明確的限制了單個用戶在同一時間不能保持兩個以上的連接,但是,現(xiàn)代瀏覽器大部分都突破了這個限制,很多瀏覽器可以支持四個甚至六個并行的連接。同樣的,你也可以將資源文件散列到不同的域名下面,這種做法充分的利用了瀏覽器并發(fā),所以可以提高加載效率,但是由于DNS的查詢有耗時,太多的域名解析又會使性能降低。

  • 合并資源文件
    并行鏈接的討論得出一個結(jié)論,大一些的文件比小一些的文件好,雖然說這個說法聽起來有些別扭,但是在現(xiàn)今的網(wǎng)絡(luò)環(huán)境里,這個說法可以得到證實(體積大的文件比多個小文件加載快)。此外每個HTTP請求在時間上和帶寬上至少會產(chǎn)生一些開銷,如果可以合并資源,減少HTTP請求,會提升一定的性能。

  • 使用圖片精靈(css sprite)
    這個名詞應(yīng)該比較熟悉和常用,它的意思就是把幾張圖片合并成一張。這是一種有效減少HTTP請求的方法,在使用圖片的時候你只需要使用一些css的定位來決定這個圖片的位置即可。當(dāng)我們使用其中的一個圖標(biāo)時,其他的圖片也會被緩存(不需要再次請求)如果有100個圖標(biāo)則可以減少99次HTTP請求。

使用CDN加速(內(nèi)容分發(fā)系統(tǒng))

CDN是一個擁有很多服務(wù)器、經(jīng)過策略性部署的、可以覆蓋全球的網(wǎng)絡(luò)系統(tǒng),當(dāng)用戶訪問一個比較大的網(wǎng)站時,CDN會從最近的一個節(jié)點為用戶提供服務(wù)。但是動態(tài)數(shù)據(jù)的處理最好放在集中的服務(wù)器中,因為跨地域同步數(shù)據(jù)庫是一個令開發(fā)者頭痛的問題,所有大多數(shù)互聯(lián)網(wǎng)公司都把購買、登陸等數(shù)據(jù)相關(guān)的事物放到一個地方處理。另外,CDN服務(wù)是很貴的,如果網(wǎng)站的流量值得去付出這么多錢,它無疑會給性能帶來提升。

避免空的src和href屬性

我們使用javascript給空的src賦值時,javascript放在文檔的最后,此時雖然src是空的仍然會發(fā)出一個HTTP請求。當(dāng)我們點擊一個空的href屬性的鏈接時,同樣會發(fā)出一個HTTP請求,雖然這個HTTP請求不會有影響加載時間但是會給服務(wù)端造成一定的流量浪費。我們可以創(chuàng)建一個帶有描述性信息的很href屬性,并阻止這次HTTP請求
<a href="#SometingDescriptive" id="TriggerName">TriggerName</a> <script type="text/javascript"> $("#TriggerName").click(function (e) { e.prventDefaulet(); // 取消默認(rèn)行為 ... }); </script>
另外,空的src和href也是會產(chǎn)生報錯的

增加過期頭

延伸閱讀

學(xué)習(xí)是年輕人改變自己的最好方式-Java培訓(xùn),做最負(fù)責(zé)任的教育,學(xué)習(xí)改變命運,軟件學(xué)習(xí),再就業(yè),大學(xué)生如何就業(yè),幫大學(xué)生找到好工作,lphotoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動軟件開發(fā)培訓(xùn),網(wǎng)站設(shè)計培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)學(xué)習(xí)是年輕人改變自己的最好方式