srcset圖片響應(yīng)式方案中的w到底是什么侦铜?

這篇文章是圖片響應(yīng)式解決方案的子文章绑蔫,屬于實驗性質(zhì)运沦。

這篇文章將解決兩個問題:

  • 瀏覽器是否是根據(jù)w值來選擇圖片的,是如何選擇的?
  • 如果w值與圖片真實寬度不一致,又會出現(xiàn)哪些問題袍睡?

最開始的時候我是理解w標志代表可渲染的位圖寬度的,那么是這樣么烈掠?做個測試
我將test-480.jpg 480w改為了450w,

<img class="image" src="test-240.jpg" srcset="test-240.jpg 240w, test-480.jpg 450w, test-720.jpg 720w sizes="240px">

如果w代表該圖片的位圖寬度的話,在dpr==2的設(shè)備上最多可渲染480px寬的位圖

dpr==2, test-480.jpg 450w

而且還發(fā)現(xiàn)256/240==480/450缸托,這個結(jié)果到底說明什么呢左敌?先不管,繼續(xù)大膽假設(shè)小心驗證俐镐。然后我們再實驗(將720px寬的圖片后的w改為了480):

<img class="image" src="test-240.jpg" srcset="test-240.jpg 240w, test-480.jpg 450w, test-720.jpg 480w" sizes="240px">
dpr==2,test-480.jpg 450w, test-720.jpg 480w

發(fā)現(xiàn)通過修改w標志真的是可以欺騙瀏覽器去選擇我們指定的圖片的矫限。也就是將w理解為該圖片的位圖寬度是沒有問題的。

那么再回到上一個測試佩抹,考慮:根據(jù)w值叼风,在沒有恰好合適的圖片選擇的情況下,瀏覽器會怎么做出決策呢棍苹?繼續(xù)試驗:在多次測試時發(fā)現(xiàn)无宿,在該情況下, test-480.jpg 對應(yīng)的w在320和321之間是個分水嶺枢里。

<img class="image" src="test-240.jpg" srcset="test-240.jpg 240w, test-480.jpg 320w, test-720.jpg 720w" sizes="240px">
dpr==2,test-480.jpg 320w, test-720.jpg 720w
 <img class="image" src="test-240.jpg" srcset="test-240.jpg 240w, test-480.jpg 321w, test-720.jpg 720w" sizes="240px">
dpr==2,test-480.jpg 321w, test-720.jpg 720w

480X1.5=720孽鸡,480/1.5=320,那么也就是瀏覽器是根據(jù)類似于等比數(shù)列而不是等差數(shù)列去做出選擇的。也就是當沒有正好寬度的圖片時栏豺,瀏覽器會根據(jù)sizes和dpr計算出正確解彬碱,然后向拉伸或者壓縮的方向以百分比的形式向外擴展,直至獲得最優(yōu)解奥洼。另外堡妒,當最優(yōu)解有兩個且分別是一個是要拉伸一個要壓縮,那么會選擇數(shù)值較大的那張圖片溉卓。
那么對于下面這個情況,也就能預(yù)測瀏覽器會選擇哪張圖片來展示:因為320w和720w距離480px是一樣近的搬泥。721w肯定就更遠一些了桑寨。

<img class="image" src="test-240.jpg" srcset="test-240.jpg 240w, test-480.jpg 320w, test-720.jpg 721w" sizes="240px">
dpr==2,test-480.jpg 320w, test-720.jpg 721w

結(jié)果支持我們的判斷。

好了忿檩,折騰這么多尉尾,我們終于可以下一個結(jié)論,w是對該圖片寬度的描述燥透,而且這會直接影響到瀏覽器對于圖片的選擇沙咏,瀏覽器選擇的標準就是根據(jù)sizes和dpr計算所得準確值在w值增大和減小的兩個方向上選擇一個比值(永遠是大數(shù)/小數(shù))更小的一個圖片顯示辨图。

還記得上面遺留的問題么?就是圖片顯示寬度并不是240px的情況肢藐。

拿離我們最近的上面這個圖片來做一個解釋:瀏覽器選擇的是這個test-480.jpg 320w故河,根據(jù)320w,瀏覽器就會認為圖片的寬度就是320px寬,此時的正確值是480吆豹,那么瀏覽器是要把320px的圖片拉伸到480px寬鱼的,也就是寬度擴大480/320=1.5倍,來使得在dpr=2的屏上顯示寬度為240px痘煤。但是圖片的實際寬度是480凑阶,所以最終的展示寬度就變成了480X1.5/2=360。所以衷快,可以補充一點宙橱,當你給照片添加的w值不準確時也是會導(dǎo)致圖片展示寬度變化的。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蘸拔,一起剝皮案震驚了整個濱河市师郑,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌都伪,老刑警劉巖呕乎,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異陨晶,居然都是意外死亡猬仁,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進店門先誉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來湿刽,“玉大人,你說我怎么就攤上這事褐耳≌┕耄” “怎么了?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵铃芦,是天一觀的道長雅镊。 經(jīng)常有香客問我,道長刃滓,這世上最難降的妖魔是什么仁烹? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮咧虎,結(jié)果婚禮上卓缰,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好征唬,可當我...
    茶點故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布捌显。 她就那樣靜靜地躺著,像睡著了一般总寒。 火紅的嫁衣襯著肌膚如雪扶歪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天偿乖,我揣著相機與錄音击罪,去河邊找鬼。 笑死贪薪,一個胖子當著我的面吹牛媳禁,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播画切,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼竣稽,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了霍弹?” 一聲冷哼從身側(cè)響起毫别,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎典格,沒想到半個月后岛宦,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡耍缴,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年砾肺,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片防嗡。...
    茶點故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡变汪,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蚁趁,到底是詐尸還是另有隱情裙盾,我是刑警寧澤,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布他嫡,位于F島的核電站番官,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏钢属。R本人自食惡果不足惜徘熔,卻給世界環(huán)境...
    茶點故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望署咽。 院中可真熱鬧,春花似錦、人聲如沸宁否。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽慕匠。三九已至饱须,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間台谊,已是汗流浹背蓉媳。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留锅铅,地道東北人酪呻。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓,卻偏偏與公主長得像盐须,于是被迫代替她去往敵國和親玩荠。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,675評論 2 359

推薦閱讀更多精彩內(nèi)容