<ul id="g60s4"><pre id="g60s4"></pre></ul>
<strong id="g60s4"><nav id="g60s4"></nav></strong>
<ul id="g60s4"></ul>
  • <tr id="g60s4"></tr>
  • 
    
  • 或者

    網站頁面精簡的10個優化技巧

    作者:數風流人物 瀏覽:148 發布時間:2017-05-10
    分享 評論 0

    據調查,網頁大小在2013年平均增長了32%,平均達到了1.7M,單獨的HTTP請求達到96個,說實話,這是一個令人震驚的數字,而且這只是個平均值,有一半的網站會大于這個值。

    那么,一個“頁面超重”的網站有什么影響呢?具體來說,有以下4點:

    ①、網站代碼越多,用戶下載的就越多,加載速度就會越慢。在國內,并不是每個人都能享受20M的寬帶,每一個開發者心里都很清楚,用戶不愿意等。

    ②、眾所周知,移動互聯網發展迅速,對于2G網絡來說,加載1.7M的頁面甚至需要一分鐘時間。

    ③、影響搜索引擎抓取速度將會對網站排名造成很大影響。

    ④、對于開發者來說,代碼量越大,就越不容易更新和維護。

    如今已經有很多人開始關注這個問題,并出現了很多優化的工具,而且這些技術都非常容易上手,不需要花太多時間,也不需要重新開發。

    在本文中,馬海祥會給大家一些建議,雖說前三個建議實際上不能給“網頁減肥”,但它們仍能有效的加快網頁加載速度。

    1、用GZIP格式壓縮

    gzip是GNUzip的縮寫,它是一個GNU自由軟件的文件壓縮程序。它是Jean-loupGailly和MarkAdler一起開發的,第一次公開發布版本是1992年10月31日發布的版本0.1,1993年2月發布了版本1.0。

    我們在Linux中經常會用到后綴為.gz的文件,它們就是GZIP格式的,現今已經成為Internet上使用非常普遍的一種數據壓縮格式,或者說一種文件格式。

    HTTP協議上的GZIP編碼是一種用來改進WEB應用程序性能的技術,大流量的WEB站點常常使用GZIP壓縮技術來讓用戶感受更快的速度。

    這一般是指WWW服務器中安裝的一個功能,當有人來訪問這個服務器中的網站時,服務器中的這個功能就將網頁內容壓縮后傳輸到來訪的電腦瀏覽器中顯示出來。

    一般對純文本內容可壓縮到原大小的40%,這樣傳輸就快了,效果就是你點擊網址后會很快的顯示出來,當然這也會增加服務器的負載,一般服務器中都安裝有這個功能模塊的。

    根據W3C組織調查,大部分的網站都沒有啟用壓縮功能。

    2、支持瀏覽器緩存

    如果瀏覽器支持緩存,我們就不用重復下載網頁資源,最簡單的設置緩存方法是在響應頭中添加相應的內容,包括:Expires header,Last-Modified等。

    你可以可以通過配置服務器來自動添加這些屬性,比如你在Apache服務器中配置緩存所有的照片一個月:

    <IfModule mod_expires.c>

      ExpiresActive On

      <FilesMatch "\.(jpg|jpeg|png|gif|svg)$">

      ExpiresDefault "access plus 1 month"

      </FilesMatch>

      </IfModule>

    3、使用內容分發網絡 (CDN)

    CDN的全稱是Content Delivery Network,即內容分發網絡。其目的是通過在現有的Internet中增加一層新的網絡架構,將網站的內容發布到最接近用戶的網絡“邊緣”,使用戶可以就近取得所需的內容,提高用戶訪問網站的響應速度。

    CDN有別于鏡像,因為它比鏡像更智能,或者可以做這樣一個比喻:CDN=更智能的鏡像+緩存+流量導流。

    因而,CDN可以明顯提高Internet網絡中信息流動的效率,從技術上全面解決由于網絡帶寬小、用戶訪問量大、網點分布不均等問題,提高用戶訪問網站的響應速度。

    為更好地理解CDN,讓我們看一下CDN的工作流程,當用戶訪問已經加入CDN服務的網站時,首先通過DNS重定向技術確定最接近用戶的最佳CDN節點,同時將用戶的請求指向該節點。

    當用戶的請求到達指定節點時,CDN的服務器(節點上的高速緩存)負責將用戶請求的內容提供給用戶。

    具體流程為: 用戶在自己的瀏覽器中輸入要訪問的網站的域名,瀏覽器向本地DNS請求對該域名的解析,本地DNS將請求發到網站的主DNS,主DNS根據一系列的策略確定當時最適當的CDN節點,并將解析的結果(IP地址)發給用戶,用戶向給定的CDN節點請求相&mdash;&mdash;應網站的內容。

    以上三個方法可以有效地加快頁面的訪問速度,現在我們將對你的代碼進行診斷,幫助我們給頁面減肥。

    4、刪除不需要的資源

    當你不再需要一個組件的時候,你應該刪掉它的CSS和JavaScript代碼,如果這些代碼都單獨放在一個文件中,那刪掉它們也不是難事,但如果已經沒有用的代碼和其它代碼在一個文件中,那你肯定要費不少精力去刪掉它們。

    這個時候你就需要使用第三方的工具來幫你一鍵解決,比如JSLint,Dust-Me Selectors,CSS Usage或是像grunt-uncss一樣的構建工具。

    5、style和font重復定義的沉余代碼

    要充分利用好CSS代碼定義自己的顏色大小等,有些網站既用了CSS代碼定義了之后又去使用style或者是font這樣的代碼進行定義,這樣就無形中增加了無用代碼,容易造成代碼冗余,因此我們要對這樣的代碼進行壓縮,實現代碼精簡。

    6、通用和最小化CSS

    理想情況下,需要一個單獨的CSS文件,讓每個頁面都調用這一個布局,當然,如果你想要支持老版本的IE,你就得多弄一個CSS文件。

    另外,馬海祥還要提醒大家一點:當你把它們構建到服務器上之前,你應該把代碼間所有不必要的格式都刪掉。

    有很多預處理工具都可以幫你解決這件麻煩事,比如Sass,LESS和Stylus。

    有一些方法可以幫助你直接合并多個CSS文件,在Windows上:

    copy file1.css+file2.css file.css

    在Mac或Linux上:

    cat file1.css file2.css > file.css

    你可以把得到的CSS文件再經過在線的CSS壓縮工具刪除格式化。

    最后,在head標簽中加載所有的CSS,這樣瀏覽器就知道你的頁面樣式不用多次重繪了。

    7、通用和最小化的JavaScript

    利用外部文件,我們可以用Javascript代碼和CSS代碼放在外部文件里面,在我們的HTML代碼里面加上調用代碼進行調用即可,如果打開一個網站去檢查它的源文件,前面如果有大量的Javascript代碼和CSS代碼就容易使得網站有用的內容文字部分推到后面去了,是不利于搜索引擎抓取的。

    據馬海祥博客收集的數據顯示:平均每個頁面加載了18個javascript文件,雖然把像jQuery這樣的庫文件單獨分開非常實用,但是你自己的JavaScript代碼應該保持通用和最小化。

    同樣很多第三方的工具可以幫你解決這樣事情,比如YUI Compressor,Closure Compiler和我最喜歡用的The JavaScript CompressorRater,簡化的JavaScript代碼會加快網頁的訪問速度,減少HTTP請求次數。

    最后,最好在HTML的body標簽后放置JavaScript引用代碼,這樣能保證JavaScript代碼不影響到其它內容的加載。

    8、減少頁面嵌套的表格

    對于表格要盡量少使用,尤其是嵌套的表格部分,雖然CSS排版使得我們編寫代碼更加的精簡容易,但往往也是少不了表格的使用的,我們可以不去避免,但一定要減少使用多層嵌套的表格,不要產生沒有用的代碼。

    9、網站圖片的優化

    對于一些圖片站來說,加載錯誤的圖片格式會對你的網頁造成很大影響,所以,馬海祥建議圖片站的站長一定要多對圖片做些優化。

    (1)、圖片優化原則

    一般來說選取圖片我們應用遵循如下原則:

    ①、照片使用JPG格式。

    ②、其它所有的圖片都使用PNG格式。

    (2)、調整大圖的大小

    目前智能機所拍出的照片越來越大,你不可能把原照片直接展示在頁面中,普通的編輯器都會直接上傳原圖,這樣會讓頁面的加載速度慢到另一個級別,在正常的照片處理中,一般都沒有必要給用戶高質量的圖片展示,所以,你需要一個自動調整圖片大小的工具。

    需要注意的是,圖片的尺寸是不能超過容量的大小的,這樣一來頁面加載了全圖,卻無法展示出來,現在照片的尺寸基本上都超過電腦顯示屏的尺寸了。

    圖片的大小在網頁總大小中占很大的比重,圖片減小50%會導致整體頁面大小減少75%,所以你應該認真解決一下圖片的加載。

    (3)、進一步壓縮圖片

    僅僅調優圖片的大小是不夠的,你應該通過第三方工具對圖片進行分析,進一步壓縮圖片。

    比較好用的工具有OptiPNG,PNGOUT,jpegtran和jpegoptim,這些工具大都能安裝成獨立的工具或是整合到開發過程中,另外像Smush這樣的工具,還可以直接在云端處理。

    10、刪除不必要的字體和注釋

    Web fonts已經徹底改變了字體的設計,它減少了很多不必要的文本,然而,目前的字體仍然會給你的網頁帶來多余的字節。

    如果你使用超過兩種字體,這就已經開始對性能造成影響了。

    網頁代碼盡量少用注釋,我們知道一段程序里面加上注釋能夠便于我們快速找到和理解具體代碼對應的功能,對于編程人員修改網頁是有幫助的,但是這樣的代碼對于搜索引擎來說是沒有任何的意義的,只能說是噪聲,因此我們要減少網頁代碼里面出現的注釋部分。

    我相信大部分網站都可以通過以上的優化減小大概30%-50%的重量,但是身為一個完美主義的開發者這是遠遠不夠的,我們在接下來的系列文章中會繼續對網站瘦身進行深入研究。



    国产精品无码A∨精品影院| 无码精品久久一区二区三区| 久久99精品国产自在现线小黄鸭| 精品视频在线观看你懂的一区| 中文字幕日韩一区| 国产精品爽爽影院在线| 亚洲国产精品无码久久98| 亚洲一区二区三区国产精品无码| 久久国产精品岛国搬运工| 国自产偷精品不卡在线| 窝窝午夜色视频国产精品东北| 国产精品龙口护士门在线观看| 无码国内精品久久人妻麻豆按摩 | 久久久久成人精品免费播放动漫| 中文字幕精品一区| 国产网红主播无码精品| 思思久久99热免费精品6 | 国产麻豆精品一区二区三区v视界| 国产精品熟女福利久久AV| 老司机午夜精品视频播放| 日韩精品一线二线三线优势| 亚洲AV日韩AV鸥美在线观看| 国产日韩在线视频免费播放 | 精品熟女少妇aⅴ免费久久| 国产精品激情综合久久| 亚洲精品无码久久久久AV麻豆| 第四色播日韩第一页| 中文字幕日韩一区二区不卡| 日韩一区二区电影| 日韩av无码中文字幕| 久久九九久精品国产日韩经典| 人妻在线日韩免费视频| 日韩av无码一区二区三区| 日韩一区精品视频一区二区| 日韩免费高清大片在线| 国产av一区二区三区日韩| 日韩成人精品日本亚洲 | 久久精品国产99精品最新| 久久青草精品38国产| 久久久国产精品一区二区18禁 | 国产成人精品怡红院|