文章詳情頁
javascript - 很多網(wǎng)頁前端都是一整個圖片裁剪出來很多小的素材比如按鈕圖標等這是為什么?手機端開發(fā)也會這么操作嗎?
瀏覽:124日期:2022-11-05 14:10:09
問題描述
比如微博的這個加v認證的圖標 為什么不讓UI分成一批文件而是在用的時候再裁剪?順便問一問在真正的開發(fā)中,手機端也會這么操作嗎?
問題解答
回答1:資源體積小, 數(shù)量多. 如果分成一批文件的話, 網(wǎng)頁加載的時候會產(chǎn)生大量的 http 請求. http 請求的建立是需要消耗設備性能和網(wǎng)絡帶寬的.
與其說為什么不分成一批文件, 倒不如說是為了提升新能而把小文件整合在一起發(fā)布.
回答2:可以搜一下 精靈圖 雪碧圖 sprite圖之類的關鍵字
回答3:這是CSS雪碧圖效果. 原理: 將小圖標和背景圖像合并到一張圖片上,然后利用css的背景定位來顯示需要顯示的圖片部分. 目的: 減少加載網(wǎng)頁圖片時對服務器的請求次數(shù),提高頁面的加載速度. 問題: 首次加載時, 內(nèi)存消耗比較大, 而且會把不需要用到的圖片或者圖標也一起加載到內(nèi)存中.
手機端一般不用雪碧圖效果. 原因是手機內(nèi)存本來就不富裕, 手機端資源加載一般都是用到的時候在去加載到內(nèi)存中(lazy load), 而且使用雪碧圖會提高圖片維護成本, 在使用圖片時需要更多的css操作來顯示指定的圖片. 同時在iOS中, 使用雪碧圖也加大了不同的手機圖片適配難度.
標簽:
JavaScript
上一條:javascript - 頁面如何獲取重定向的url?下一條:javascript - react-native在chrome調(diào)試工具中出現(xiàn)警告,并且不能使用react dev-tools
相關文章:
1. android-studio - Android Studio 運行項目的時候一堆警告,跑步起來!?2. mysql - 新浪微博中的關注功能是如何設計表結構的?3. angular.js使用$resource服務把數(shù)據(jù)存入mongodb的問題。4. 如何解決Centos下Docker服務啟動無響應,且輸入docker命令無響應?5. angular.js - 關于$apply()6. dockerfile - [docker build image失敗- npm install]7. MySQL數(shù)據(jù)庫中文亂碼的原因8. 表單提交驗證,沒反應,求老師指點9. nignx - docker內(nèi)nginx 80端口被占用10. angular.js - Ionic 集成crosswalk后生成的apk在android4.4.2上安裝失敗???
排行榜

熱門標簽