你知道嗎?為網站減負的十大措施

来源:http://www.cnblogs.com/shouce/archive/2016/01/16/5134905.html
-Advertisement-
Play Games

網站快速載入,是提供良好用戶體驗的前提。然而,網站功能的不斷增多,程式包的不斷臃腫,導致網站訪問時較大的下載量,最終影響了響應速度。沒有一個用戶喜歡等待,如何減少代碼量,為網站減去過多負擔,Craig Buckler在sitepoint網站發表了一篇文章《10 Quick and Easy Fixe...


網站快速載入,是提供良好用戶體驗的前提。然而,網站功能的不斷增多,程式包的不斷臃腫,導致網站訪問時較大的下載量,最終影響了響應速度。沒有一個用戶喜歡等待,如何減少代碼量,為網站減去過多負擔,Craig Buckler在sitepoint網站發表了一篇文章《10 Quick and Easy Fixes to Reduce Page Weight》,分享為網站減負的十個建議。下麵為該文的編譯內容。

  網站頁面的重量增加了32%,竟然達到了1.7MB,包含96個獨立HTTP請求。這隻是一個平均數值,其中近一半的網站已經超過了這個數值。網站的過度臃腫正趨於流行,其中很大的責任在於Web開發者。

  過於笨重的網站將嚴重影響網站的最終體驗,主要表現在以下四個方面:

更大的下載量,導致更慢的用戶體驗。並不是每個人都擁有20M的網路連接,尤其是對於那些不發達地區。不管你的網站多麼優秀,用戶永遠不希望等待。
移動Web訪問正迅速發展,移動網民幾乎占到所有網民的1/4。在典型的3G網路連接下,一個1.7Mb的網站載入需要近一分鐘。如果你的網站無法高效工作於這些移動設備,那採用響應式Web設計技術又有什麼用呢?
網站載入速度已被谷歌加入排名演算法中。載入緩慢會降低網站排名,同時也會影響搜索引擎優化。
網站包含的代碼越多,更新和維護它所花費的時間就會越長。
  Craig Buckler預言,網頁的重量將會下降。那如何精簡代碼,為網站減負呢?Craig Buckler給出了十條建議。這些建議中涉及到的技術均是大家熟知的。

  1.啟用GZIP壓縮

  根據 W3Techs.com上的數據顯示,近一半的網站都未進行過壓縮。在Web主機上,通過簡單的伺服器設置即可開啟GZIP壓縮。

  2.支持瀏覽器緩存

  如果瀏覽器能容易地緩存一個文件,那它就無需反覆下載該文件了。實現該功能的一個解決方案,就是在HTTP頭中設置合適的 Expires Header、上一次修改時間或採用的 ETags。

  你可通過配置伺服器來自動完成以上工作。下麵是Apache中的.htaccess文件,其中的代碼實現了“將所有圖片緩存一個月”的功能。

<IfModule mod_expires.c>
ExpiresActive On

<FilesMatch "\.(jpg|jpeg|png|gif|svg)$">
ExpiresDefault "access plus 1 month"
</FilesMatch>

</IfModule>

  

  3.使用CDN

  瀏覽器限制了每個域中可同時處理的併發HTTP請求數量:4至8個。如果你的網頁需要從域中載入96個資源,那瀏覽器最多可設置12組併發請求。(因為文件大小並不同,這種情況實際上並不會發生,但該限制仍然適用。)

  如若從另一個域中請求靜態文件,則可使瀏覽器處理的HTTP請求數量加倍。此外,一個文件被調用後就會產生一個緩存文件,以供下一個調用它的網站使用。我們可選用JavaScript庫(如jQuery)和字體庫,同時你也可以考慮專用的圖片托管。

  前面提到的三條建議可以加快網站的載入速度,下麵的建議將幫助我們檢查網站代碼,以高效地減少網站重量。

  4.刪掉沒用的資源

  網站一直在變革之中。如果你不再使用某組件,那就刪掉與之關聯的CSS和JavaScript。如果它們包含在一個單獨文件中,處理起來就會很簡單。否則,你需要藉助一些工具,如Chrome的Audit開發工具、JSLint、 Dust-Me Selectors、 CSS Usage、 unused-css.com,也可構建 grunt-uncss此類的工具。

  5.合併和壓縮CSS

  理想的情況是只擁有一個CSS文件(如果你使用RWD以支持IE的老版本,那就需要兩個CSS文件。)構建並維護幾個單獨的CSS文件也算合理,但在部署到產品伺服器之前,你應該將它們集合在一起,並刪掉那些不必要的空白區域。

  Saas、LESS和Stylus等預處理器可幫你完成這些痛苦的工作。 Grunt.js、 Gulp等工具可自動化你的工作流。如果你更喜歡GUI,可藉助Koala提供的免費跨平臺應用。

  如果你覺得這些比較麻煩,也可手動通過命令行工具將CSS文件集中在一起,如在Windows中,可使用如下代碼:

 

copy file1.css+file2.css file.css

  

  在Mac/Linux中,可使用如下代碼:

cat file1.css file2.css > file.css

  


  最終文件經過線上CSS壓縮工具(如 cssminifier.com、 CSS Compressor & Minifieror等)壓縮後即可運行。

  最後,請記住在頭部(Head)載入所有CSS,以便瀏覽器展示接下來的HTML元素,同時也可避免瀏覽器下次再重繪頁面元素。

  6.壓縮併合並JavaScript

  平均每個頁面需載入18個JavaScript文件,所以我們要將自己編寫的JavaScript代碼進行合併和壓縮。我們可以自己構建壓縮工具,也可以使用線上工具,如 YUI Compressor、 Closure Compiler及CompressorRater。

  使用JavaScript壓縮工具進行壓縮,必須十分謹慎。你的代碼有一點小問題,即便丟失了一個分號,壓縮過程也可能會失敗。無論如何,對JavaScript文件進行壓縮,可減少HTTP請求數量,從而提高網站性能。

  最好在</body>之前載入JavaScript,這樣可確保該腳本不會阻礙其它內容的載入,同時在該腳本被下載和執行之前,頁面的內容已載入完畢,並可閱讀了。

  7.使用正確的圖片格式

  錯誤地使用圖片格式會增加網頁的負載。圖片格式通常有以下使用原則:

照片使用JPG格式;
其他的使用PNG格式。
  當你有一些小圖像,它們僅包含有限的幾種色彩集,採用GIF格式,其壓縮效果可能更好。本文暫不討論向量圖。

  現在有大量免費的圖形軟體包,可用來轉換圖片的格式。其中像XnView允許你批處理這些文件。請記住下麵兩條原則:

  JPG為一種有損壓縮格式,其質量介於0(質量很差、更小的文件)至100(質量最好,更大的文件)之間。介於30至70之間的大部分圖片顯示效果比較好。

  PNG支持256顏色表和24位的真彩色。如果你不需要透明,並能控制調色板,那256的PNG圖像顏色模式可能壓縮得更好。

  8.重整大圖片的尺寸

  即便是最入門級的智能手機上的照片機(三百萬像素),其拍出來的照片往往太大而不適合在網站上顯示。但大部分內容編輯者往往將圖片直接從相機中直接上傳到網站上。因此,我們需要一個可以自動調整圖片尺寸的系統。

  圖片的尺寸永遠不能超過它所在容器的最大值。如果網站模板的寬度最大為800px,那圖片的寬度就不能超過該值。一些高解析度、Retina顯示屏,可顯示寬度為1600px的圖片,但這仍比從相機中直接輸出的圖片要小。

  在減輕網頁重量方面,圖片尺寸的調整起著重要的作用。將圖片尺寸縮小50%,可節省75%的總空間,相當於減少了文件大小。

  9.進一步壓縮圖片

  即便已將圖片調整為正確的格式和尺寸,你仍可使用一些分析和優化圖像的工具進一步壓縮圖片。這些工具包括 OptiPNG、 PNGOUT、 jpegtran和 jpegoptim。大部分工具可獨立安裝,也可整合入你構建的過程中。另外,還有一些線上工具,如Smush,它可以工作於雲上。

  10.去掉不必要的字體

  Web字體對設計進行了重大改革,減少了基於圖像的字體的使用。但是,使用傳統字體後,網頁的代碼量往往會增加數百KB。所以網站中這種字體的使用儘量控制在兩、三種以內。

  利用以上提到的方法,大部分網站可以將減去30~50%的重量。對於一般的網站,可以減掉800KB的代碼量,訪問速度可獲明顯提升。(編譯:陳秋歌)


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 什麼是const限定符?Const限定符是我們通常所說的常量限定符,被const修飾的對象具有常量性質,只能讀,不能寫。為什麼使用const限定符?用const變數取代“魔數”,代碼更容易理解和維護。例如:以const常變數作為數組的界;const常變數作為switch的條件標號。C++“最小特權原...
  • 北京尚學堂提供1.Java集合框架是什麼?說出一些集合框架的優點?每種編程語言中都有集合,最初的Java版本包含幾種集合類:Vector、Stack、HashTable和Array。隨著集合的廣泛使用,Java1.2提出了囊括所有集合介面、實現和演算法的集合框架。在保證線程安全的情況下使用泛型和併發集...
  • BAT站在中國互聯網的頂端,引導著中國互聯網的發展走向。。。既受到了多數程式員的關註,也在被我們所惦記著。。。 關於SmartQQ的協議來自HexBlog,根據他的博客我自己也一步一步的去分析,去嘗試,自己不瞭解不知道的總是神秘的,如果你有這種好奇心,那麼真相就只有一個。接下來我先把協議放出來...
  • 在Centos or redhat 安裝Sphinx1.首先安裝依賴包$ yum install postgresql-libs unixODBC2.安裝軟體$ rpm -Uhv sphinx-2.2.1-1.rhel6.x86_64.rpm3.啟動服務$ service searchd start...
  • 1、這種上傳方式是用admin後臺完成的,用資料庫和model做vim settings.pyMEDIA_ROOT = '/headImg/' 文件保存在路徑(還有後續)# 'django.middleware.csrf.CsrfViewMiddleware', 禁掉這個,跨站不會出問題'djan....
  • 選擇器(selector)是CSS中很重要的概念,所有HTML語言中的標記都是通過不同的CSS選擇器進行控制的。用戶只需要通過選擇器對不同的HTML標簽進行控制,並賦予各種樣式聲明,即可實現各種效果。 1.** { margin: 0; padding: 0; } 星號選擇器用於選取頁面中的所有元....
  • 瀏覽器檢測通常都是通過分析用戶代理字元串(navigator.userAgent)來進行檢測。由於國內瀏覽器用的內核多是國外的,所以很多特性無法與國外瀏覽器區分,所以要先檢測國外瀏覽器,再檢測國內瀏覽器。這樣當國內瀏覽器沒有找到匹配項時就是內核預設的國外瀏覽器。function checkChine...
  • 對於瀏覽器相容問題,我們應該碰到很多了,在平時寫一些頁面時,在IE8、IE9上可能好好的,當我們在IE6、IE7或者是其他的瀏覽器上再瀏覽這些頁面時,可能會發現我們的頁面已經面目全非了,作為一名前端開發人員,這是最讓人發瘋的問題了,那麼我們該怎麼解決這些問題呢?首先,我們寫的頁面在不同的瀏覽器上之所...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...