前端開發(fā)中的圖片優(yōu)化 |
發(fā)布時間:2020-06-03 文章來源:本站 瀏覽次數(shù):2532 |
現(xiàn)在的互聯(lián)網,是一個用戶體驗至上的年代,大多數(shù)公司都會把怎么進步產品的易用性放在首要位置。怎么進步產品的質量則體現(xiàn)在項目開發(fā)的許多階段,例如產品規(guī)劃、UI規(guī)劃和前端開發(fā)等。而圖片優(yōu)化在進步產品質量上也起到了無足輕重的作用,這也便是為什么越來越多的產品團隊愈加重視這個問題。 本文關于圖片優(yōu)化的內容首要由兩部分構成: 1. 收拾總結網上關于圖片優(yōu)化的一些辦法辦法。 2. 自己在項目開發(fā)過程中實際遇到的問題以及用到的圖片優(yōu)化計劃。 如有不足之處,歡迎咱們指出并補充。 1. 精約而不簡單 Win8和iOS7的出現(xiàn),將互聯(lián)網職業(yè)中許多產品規(guī)劃帶回到原點,或許更是另一個新的起點。Win8的Metro UI、iOS7中圖標的扁平化規(guī)劃、一直崇尚精約的豆瓣網、還有頂著年代工匠稱號的老羅所規(guī)劃的錘子ROM,無一不體現(xiàn)著精約的風格。 言歸正傳,回到咱們圖片優(yōu)化的主題上。在產品規(guī)劃和UI規(guī)劃階段,除了內容圖片,其他的圖片都是起潤飾的作用。也便是關于傳遞信息來說并非實質性的。所以最大的優(yōu)化便是不要圖片。在進入到研制階段之前,就要承認規(guī)劃,規(guī)劃本身是否需求用到那么多的圖片,還是說能夠做到更簡練! 2. 款式替代圖片 Chrome,F(xiàn)F等瀏覽器廠商為互聯(lián)網的開展做了這么多奉獻,為什么咱們還要讓那些不兼容CSS3的瀏覽器阻止互聯(lián)網的開展呢。因而,讓咱們直接運用CSS款式替代圖片來實現(xiàn)潤飾作用!例如:半通明、圓角、暗影、高光、突變等。這些作用主流的瀏覽器都能夠完美支撐,而關于那些低端瀏覽器,咱們并不會完全拋棄他們,“漸進增強”則是一個很好的解決計劃。至于什么是漸進增強,這兒不再用過多篇幅去解說,假如感興趣能夠參考CSS“漸進增強”在web制造中常見運用舉例。 3. 挑選最合適的圖片 咱們常見的圖片格局有JPEG、GIF、PNG。 基本上,內容圖片多為照片之類或圖片構成較復雜的狀況,適用于JPEG。如網站中的Banner圖、輪播圖、大尺度背景圖等。 潤飾圖片通常更適合用無損緊縮的PNG。而咱們首要用到的PNG圖片又分為PNG-8和PNG-24兩種,PNG-8格局不支撐半通明,也是IE6兼容的圖片存儲辦法。假如對圖片質量要求較高的半通明或全通明背景,保存成PNG-24更合適。有時候會遇到在IE6下運用PNG-24圖片的狀況,關于IE6下PNG Alpha通明的解決計劃能夠參考IE6中PNG Alpha通明。我在項目中常用的辦法是AlphaImageLoader挑選器。 GIF基本上除了GIF動畫外不要運用。 除了這些格局之外,Chrome、新版Opera、Android 4+支撐WebP格局,IE 9+、IE mobile 10+支撐JPEG XR。這兩個新格局都支撐無損和有損緊縮,都具有更良好的緊縮比。當然這需求為不同的瀏覽器回來不同的圖片,添加了開發(fā)本錢,也添加存儲本錢。不過你省了流量或者相同流量下改進了圖片質量,提升了用戶體驗。這就需求依據(jù)項目需求進行取舍了。 4. 常用的圖片優(yōu)化技巧 CSS Sprites,將同類型的圖標或按鈕等背景圖合到一張大圖中,削減頁面懇求。 Icon Font,將圖標做成字體文件。長處是圖標支撐多個尺度,兼容所有瀏覽器,削減頁面懇求等。美中不足的是只支撐純色的icon。 SVG,關于絕大多數(shù)圖案、圖標等,矢量圖更小,且可縮放而無需生成多套圖,F(xiàn)在主流瀏覽器都支撐SVG了,所以可放心運用! 圖片緊縮工具,能夠在圖片上線前運用緊縮工具進行緊縮,獲得更高的緊縮比。我常用的緊縮工具為Yahoo的Smush.it。 5. 適用各種資源而不限于圖片的優(yōu)化 data url Base64是網絡上最常見的用于傳輸8Bit字節(jié)的編碼辦法之一,可用于在HTTP環(huán)境下傳遞較長的標明信息。將圖片轉化為base64編碼格局,資源內嵌于CSS或HTML中,不用獨自懇求。 該辦法的長處是: 1. 削減了HTTP懇求 2. 避免了圖片從頭上傳,還要整理緩存的問題 不足之處是: 1. IE6, IE7不支撐該類型編碼的圖片作為背景圖 2. 添加了CSS文件的尺度 3. 保護本錢較高 按照HTTP協(xié)議設置合理的緩存 詳細的緩存策略(如永久緩存 + 重命名)、布置策略(如反向署理、CDN等)這兒就不展開了。 Responsive規(guī)劃 為了習慣現(xiàn)在眾多分辨率和設備像素比的移動設備,要發(fā)生多套不同大小和分辨率的圖片,然后配合Media Query進行開發(fā)。這兒推薦在進行移動端頁面開發(fā)時運用SVG或Icon Font等技能。這些技能能夠完美支撐Retina設備。 以上為項目中常用的圖片優(yōu)化技能,只有更多地重視細節(jié),才干做出優(yōu)秀的產品。 |
|