久久精品国产99国产精品免费看_中文成人在线_日本在线播放视频_精品国产一区二区三区在线观看

圖片橫向排版最佳實踐 - CSS筆記

本文主要說圖片的橫向排版

將圖片排版引入到博客中是我自己的一個小需求。有時候想要分享一些平時的隨手拍,但是直接在網頁上一張張堆疊照片又顯得并不美觀,因此著手研究這個功能。

第一次的嘗試實現是在 RAW 主題里,在這里可以看到效果。看似還行,但其實非常 naive,在許多情況下都會出現 bug 導致版式錯亂。

目前我的最佳實現已經應用在了 VOID 主題中。另外,VOID 主題用戶中也有深度使用了這個功能的,例如這里,效果也足夠令人滿意,那么這篇文章就說說實現細節。

常見的圖片排版方式

在網頁上展示圖片集合一般有幾種方式:裁切為正方形、縱向瀑布流、橫向排版。當然除了這三者,還有諸如 slider、popover 等展示方式,這些展示方式不在本文討論之列。

裁切為正方形的展示方式很常見,微博、朋友圈等都是這樣;Twitter 雖然有些許變化(不是所有的圖片都等大),但是也在裁切為正方形的陣營里。背后的原因有產品上的考慮,也有技術上的考慮,在此不多說。但是若從個人分享攝影作品的角度來說裁切為正方形算不上是好的方案,因為總有一部分像素會丟失,除非看客有意點擊展開,否則這部分內容就沒有機會被展示了。況且某些照片有著精妙的構圖,沒人希望自己的構圖被破壞。

縱向瀑布流也是很常見的展示方式,主要應用在專職展示圖片的網站上,例如?PinterestUnsplash。這種展示方式的特點是列數一定,但是每列中的圖片高度不一,圖片能夠保持自己的寬高比。這是不錯的方案,特別是應用在無限滾動的網頁上,不過也有一個相當大的缺點:不適合圖文混排。圖片列數一定,每列高度不同,自然使得最底下一行參差不齊,不適合作為文章中插入圖片的方式。另外,這個方式有一個缺點:圖片順序不易保持,這是縱向瀑布流的通病,因此不論是內容塊還是圖片,縱向瀑布流都更適合順序不那么重要的場景。

以上兩種方式各自有自己的應用場景,但不是本文要重點講的方式,因此其技術細節也就略過了(實際上也不難)。本文主要說圖片的橫向排版,效果如下(請在電腦端查看完整效果):

圖片橫向排版最佳實踐 - CSS筆記

特點顯而易見:圖片排版以行為單位,每行中可以有任意張任意寬高比的圖片,因此只需要處理一行中的圖片排版問題,那么無論再來多少行效果都令人滿意。應用這種排版方式的網站有?500px百度圖片等。

實現細節

HTML 與 CSS

我們只關注一行圖片。為了使文章具有足夠的參考價值,我這里使用完整的 HTML 結構(這也是 VOID 使用的 HTML 結構):

<div class="photos">
    <figure>
        <div><img src="..." /></div>
        <figcaption>...</figcaption>
    </figure>
    ...    <!--若干個類似的 figure 結構-->
</div>

使用 figure 標簽是為了使每張圖片都有完整的展示與圖題。照例,看 Demo:

從 HTML 結構中可以看出,div.photos?是一行圖片的容器,每張圖標使用?figure?包裹,并且在?img?標簽外套上一層?div,這是為了模擬某些情況下的特殊需求(例如燈箱)。

最外層的容器?div.photos?設定為 flex 布局,方向為橫向(flex-wrap: wrap 是為了在小屏幕下使用媒體查詢使圖片每張占一行,否則圖片就會小得看不清了……)。

figure?標簽除了一個 margin 屬性用來控制間距和一個 position 屬性來指定定位方式之外沒有更多的內容。figure?下的?div?標簽顯式地指定了 height 為 0,并指定了 position 為 relative。這兩個標簽上的樣式并不多,但是圖片排版全看這兩個標簽的定位與尺寸,這部分放到后面。

首先不妨假設?div?標簽與?figure?標簽都有了合適的大小,那么?img?很好處理,指定為絕對定位,并且使之長寬等于父元素的長寬即可。現在就來看看如何使?div?標簽與?figure?標簽合理布局。

關鍵的部分

核心知識點有兩個:padding-top?與?flex-grow

padding-top 用來保持寬高比的 trick 想必很多人都知道。根據?MDN

當內邊距(padding)是一個百分比的時候, 百分比是和包含塊(containing block)的寬度有關的...

當 img 標簽的直接父元素(即 div)得到了合理的寬度,然后通過 padding-top 屬性來維持容器寬高比與圖片寬高比相同。這樣 div 本身 height 為 0,但是通過 padding-top 將它撐大,img 標簽相對它絕對定位,尺寸與之相同,就是合理的結果。

最后只剩下一個關鍵的點:img 父元素即 div 的寬度如何確定。這個問題就是解決如何將一批長寬比不盡相同的圖片塞到一行里并且保證底部平齊。

這里用到了 flex 布局的一個知識點:flex-grow。flex 布局中允許容器中的元素拉伸以填充整個容器的可用空間,其中每個子元素的拉伸比例即可通過 flex-grow 定義。例如:

div:nth-of-type(1) {flex-grow: 1;}
div:nth-of-type(2) {flex-grow: 3;}
div:nth-of-type(3) {flex-grow: 1;}

這段 CSS 使得第二個元素在拉伸時寬度總是別的元素的 3 倍。flex-grow 的值不重要,值之間的比值才重要。若能夠在拉伸時保持各元素的比例,那么事情就變得簡單了一些:只需要先把一行元素的高度都搞到相同,然后在橫向按比例拉伸,那么問題便解決了。

圖片橫向排版最佳實踐 - CSS筆記

先說實踐方案,首先定義一個“基準值”(上面的 Demo 中是 50),然后計算把每張圖片都縮到高度為基準值時圖片的寬度。設圖片原始寬度為?ww?與?hh,基準值?base=50base=50?,則圖片等比縮到 50px 時的寬度為:

圖片橫向排版最佳實踐 - CSS筆記

對每個容器如此處理,即可得到一行高度為 50px 且寬高比與圖片相同的容器,這時再指定 flex-grow 使容器填充一行內的可用空間。這一步很巧妙,每個容器的 flex-grow 只需要設置為:

圖片橫向排版最佳實踐 - CSS筆記

也就是 flex-grow 與?w'w′?恰好相同即可。這是由于前面所述的,“flex-grow 的值不重要,值之間的比值才重要”。此時就完成了整個排版,至于如何獲得圖片的原始尺寸等屬于細枝末節的問題,看 Demo 代碼即可。

這篇文章也屬于 VOID 主題開發過程的技術筆記。寫主題好玩,寫完了繼續維護就不好玩了……希望到 2.0 版本的時候能夠到達比較穩定的狀態,然后就進入 LTS 階段吧。

給TA贊賞
共{{data.count}}人
人已贊賞
??
Npcink上的部份代碼及教程來源于互聯網,僅供網友學習交流,若您喜歡本文可附上原文鏈接隨意轉載。
無意侵害您的權益,請發送郵件至 1355471563#qq.com 或點擊右側 私信:Muze 反饋,我們將盡快處理。
?
購物車
優惠劵
搜索
久久精品国产99国产精品免费看_中文成人在线_日本在线播放视频_精品国产一区二区三区在线观看

    国产三级欧美三级| 久久精品国产v日韩v亚洲| 国产精品影音先锋| 久久久五月婷婷| 亚洲欧美日韩国产| 亚洲欧洲在线观看| 精品成人一区| 国产女精品视频网站免费| 欧美精品免费播放| 久久综合五月天婷婷伊人| 亚洲欧美日韩电影| 一区二区三区高清在线 | 午夜精品一区二区三区电影天堂 | 日韩亚洲国产欧美| 在线播放豆国产99亚洲| 国产日韩欧美视频在线| 国产精品久久久久久福利一牛影视| 欧美一区二区三区喷汁尤物| 99精品欧美一区二区三区| 亚洲大片一区二区三区| 狠狠色丁香久久婷婷综合_中| 欧美体内she精视频| 欧美深夜福利| 国产精品v亚洲精品v日韩精品 | 国产亚洲欧美激情| 国产婷婷一区二区| 国产亚洲一二三区| 国产一区二区精品在线观看| 国产欧美在线播放| 国产一区二区三区四区五区美女| 欧美日韩一区视频| 国产精品啊v在线| 国产精品亚洲激情| 国产一区二区三区四区三区四| 欧美日韩一区综合| 国产精品成人免费视频| 国产精品久久久久av免费| 国产精品美女久久久浪潮软件| 欧美日韩激情网| 欧美视频日韩视频在线观看| 国产精品超碰97尤物18| 国产精品夜色7777狼人| 国产一区二区成人久久免费影院| 国产精品亚发布| 一区免费在线| 一本色道久久综合狠狠躁篇的优点 | 久久国产精品高清| 欧美一区二区三区电影在线观看| 亚洲美女精品成人在线视频| 日韩视频国产视频| 欧美亚洲一区三区| 欧美国产精品久久| 欧美日韩一区在线观看视频| 国产一区二区三区四区老人| 亚洲精品美女91| 亚洲欧美日韩视频二区| 久久在线免费视频| 欧美午夜一区| 激情成人亚洲| 国产精品99久久久久久久久| 午夜影院日韩| 欧美美女操人视频| 国产一区二区三区四区| 一本色道久久加勒比88综合| 久久av一区二区三区漫画| 欧美激情在线观看| 韩日精品在线| 亚洲一区二区三区三| 久久这里有精品视频| 国产精品视频免费观看| 亚洲大胆av| 欧美一级播放| 欧美日韩亚洲网| 一区二区三区我不卡| 亚洲性夜色噜噜噜7777| 欧美va亚洲va香蕉在线| 国产一区二区精品久久| 亚洲一区二区三区在线视频| 欧美国产91| 激情亚洲成人| 久久狠狠亚洲综合| 国产精品国产馆在线真实露脸| 狠狠色丁香婷综合久久| 午夜精品在线视频| 国产精品爱久久久久久久| 亚洲另类在线视频| 欧美福利影院| 91久久极品少妇xxxxⅹ软件| 久久免费视频这里只有精品| 国产一区二区三区久久悠悠色av| 日韩一级欧洲| 欧美片在线观看| 亚洲狼人综合| 欧美日韩中文字幕| 亚洲精品影院在线观看| 欧美精品免费看| 亚洲精品一区二区三区在线观看| 久久蜜桃av一区精品变态类天堂| 国产精品午夜在线观看| 亚洲一区免费| 国产欧美大片| 久久精品国产一区二区三| 国产一区激情| 麻豆成人综合网| 亚洲国产精品精华液网站| 欧美国产激情二区三区| 亚洲精品日韩激情在线电影| 欧美—级在线免费片| 日韩一二在线观看| 国产精品三级视频| 久久aⅴ国产欧美74aaa| 亚洲国产精品传媒在线观看| 欧美岛国激情| 国产精品99久久久久久久久| 国产精品久久久久久超碰| 亚洲欧美三级伦理| 激情六月婷婷久久| 欧美精品久久一区| 午夜精品国产更新| 黄色欧美日韩| 欧美视频一区二区三区| 欧美在线视频免费| 最新国产成人av网站网址麻豆| 欧美精品18videos性欧美| 亚洲午夜av电影| 国外视频精品毛片| 欧美精品七区| 久久精品国产99国产精品| 亚洲精品久久久久久一区二区| 欧美日本国产视频| 欧美在线观看天堂一区二区三区| 在线观看一区二区精品视频| 欧美激情1区| 久久大香伊蕉在人线观看热2| 欧美日韩高清在线播放| 欧美日韩一级大片网址| 亚洲一区二区三区免费视频| 国产伊人精品| 欧美精品久久一区二区| 久久精品论坛| 亚洲一区二区三区高清 | 欧美日韩另类综合| 欧美一级黄色录像| 亚洲天堂免费在线观看视频| 在线看片一区| 国产一区二区三区久久久久久久久 | 午夜精品一区二区三区电影天堂 | 亚洲欧美区自拍先锋| 亚洲精品系列| 尤物九九久久国产精品的分类| 欧美伦理视频网站| 免费看成人av| 免费高清在线视频一区·| 性久久久久久久| 在线视频你懂得一区| 亚洲精品久久久久| 亚洲国产aⅴ天堂久久| 国产一区二区三区在线观看精品 | 亚洲永久在线观看| 亚洲国产日韩美| 在线激情影院一区| 国语精品中文字幕| 黑人中文字幕一区二区三区| 国产亚洲一级高清| 国产亚洲aⅴaaaaaa毛片| 国产伦精品一区二区三区视频孕妇| 欧美精品一区二区三区蜜桃| 欧美91精品| 欧美伦理一区二区| 欧美日韩在线精品一区二区三区| 能在线观看的日韩av| 麻豆亚洲精品| 欧美国产日韩一区二区在线观看| 久久久精品999| 久久婷婷国产综合尤物精品| 久久天堂成人| 欧美黄色一级视频| 欧美国产日本在线| 欧美日韩精品一区| 国产精品亚洲美女av网站| 国产日韩三区| 在线精品亚洲| 99国产精品私拍| 午夜精品影院| 蜜臀91精品一区二区三区| 欧美精品成人91久久久久久久| 欧美www在线| 欧美视频精品一区| 国产一区二区成人| 91久久国产综合久久91精品网站| 亚洲激情一区| 午夜精品国产更新| 欧美 日韩 国产在线| 国产精品v欧美精品v日本精品动漫 | 亚洲直播在线一区| 久久久亚洲人| 欧美日韩日本国产亚洲在线| 国产伦精品一区二区三区视频孕妇| 国产精品久久一区二区三区| 伊人婷婷久久|