久久精品国产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国产精品免费看_中文成人在线_日本在线播放视频_精品国产一区二区三区在线观看

    9000px;">

      久久精品视频一区二区三区| 久久网站热最新地址| 91麻豆精品国产综合久久久久久| 国产激情91久久精品导航| 精品久久久久久最新网址| 精品综合免费视频观看| 国产视频视频一区| 99久久精品一区二区| 亚洲国产综合人成综合网站| 91麻豆精品国产91久久久久久 | 精品视频免费在线| 图片区日韩欧美亚洲| 日韩一区二区在线看| 国产成人免费在线| 一区二区三区精密机械公司| 日韩欧美视频在线| 99久久99久久综合| 精品午夜久久福利影院| 亚洲视频免费在线| 日韩欧美国产综合在线一区二区三区| 视频一区二区三区入口| 中文一区一区三区高中清不卡| 色婷婷综合激情| 精品一二线国产| 一区二区三区在线播| 精品88久久久久88久久久| 欧美网站一区二区| 99久久婷婷国产综合精品电影| 午夜精品久久久久久久99樱桃| 欧美成人vps| 欧美午夜在线一二页| 国产成人无遮挡在线视频| 免费观看一级特黄欧美大片| 一区二区三区小说| 中文欧美字幕免费| 精品女同一区二区| 制服丝袜亚洲色图| 欧美影院精品一区| 91色视频在线| 91在线精品秘密一区二区| 国精产品一区一区三区mba桃花 | 麻豆精品一区二区| 亚洲一区日韩精品中文字幕| 1区2区3区国产精品| 日本一区二区动态图| 26uuu亚洲| 精品欧美黑人一区二区三区| 欧美精品v日韩精品v韩国精品v| 成人va在线观看| 处破女av一区二区| 国产成人av福利| 国产传媒一区在线| 丁香婷婷综合色啪| 国产成人午夜高潮毛片| 国产成人小视频| 成人午夜私人影院| a4yy欧美一区二区三区| 99精品欧美一区二区蜜桃免费| 国产馆精品极品| 成人综合日日夜夜| av影院午夜一区| 在线视频中文字幕一区二区| 欧美性受xxxx| 欧美男女性生活在线直播观看| 91成人在线精品| 51久久夜色精品国产麻豆| 日韩一区二区在线观看视频| 日韩一区二区三区视频| 精品国产一区二区三区忘忧草 | 国产盗摄一区二区| 91香蕉视频在线| 欧美高清性hdvideosex| 欧美大黄免费观看| 国产精品午夜久久| 亚洲一级二级在线| 精品在线亚洲视频| av电影在线观看完整版一区二区 | 青青草成人在线观看| 狠狠狠色丁香婷婷综合激情| 国产成人久久精品77777最新版本| 国产精品中文字幕一区二区三区| 国产一区二区三区美女| 99re视频精品| 欧美一区二区视频网站| 中文无字幕一区二区三区| 一区二区三区视频在线看| 中文字幕一区二区三区蜜月| 亚洲一区二区欧美日韩| 狠狠色丁香婷综合久久| 91老司机福利 在线| 91精品午夜视频| 国产精品久久久久久久第一福利 | 日韩欧美的一区二区| 久久久精品影视| 樱花影视一区二区| 国产成人免费视频网站| 777午夜精品免费视频| 中文字幕第一区第二区| 日韩电影在线免费| 91啪亚洲精品| 久久久美女毛片| 日本最新不卡在线| 欧美中文字幕一区二区三区 | 国产成人精品亚洲午夜麻豆| 精品视频在线免费| 亚洲欧美一区二区三区孕妇| 久久99精品国产麻豆不卡| 色综合久久综合中文综合网| 久久先锋影音av鲁色资源| 日一区二区三区| 欧美网站大全在线观看| 亚洲视频每日更新| 成人97人人超碰人人99| 欧美大胆人体bbbb| 日本不卡123| 欧美一区二区在线播放| 亚洲va国产天堂va久久en| 欧美伊人精品成人久久综合97| 久久久久久久性| 韩国在线一区二区| 久久免费美女视频| 韩国欧美国产一区| 精品久久人人做人人爰| 美脚の诱脚舐め脚责91 | 久久久久久一二三区| 美女网站一区二区| 日韩精品在线网站| 精品伊人久久久久7777人| 日韩欧美久久久| 精油按摩中文字幕久久| 欧美精品一区二区高清在线观看| 亚洲电影一区二区| 欧美精品一二三四| 奇米亚洲午夜久久精品| 精品国产百合女同互慰| 粉嫩欧美一区二区三区高清影视| 久久久久国产精品麻豆ai换脸| 视频一区二区三区在线| 欧美一二三在线| 精品亚洲国内自在自线福利| 久久综合999| 丁香五精品蜜臀久久久久99网站| 久久久久成人黄色影片| 国产高清不卡一区二区| 亚洲女人的天堂| 欧美精品三级在线观看| 国产又黄又大久久| 国产精品久久久久三级| 色综合久久天天| 午夜激情久久久| 久久品道一品道久久精品| 岛国一区二区三区| 亚洲国产一区二区在线播放| 欧美成人r级一区二区三区| 国产成人在线免费观看| 亚洲综合网站在线观看| 日韩精品一区二区三区swag| 成人一区在线观看| 午夜免费久久看| 国产日韩av一区| 欧美日韩日日骚| 顶级嫩模精品视频在线看| 亚洲最大的成人av| 久久日韩粉嫩一区二区三区| 色哟哟国产精品免费观看| 日韩精品成人一区二区在线| 欧美激情综合五月色丁香小说| a美女胸又www黄视频久久| 日韩国产欧美三级| 日韩理论片一区二区| 精品久久久久99| 91高清在线观看| 成人精品亚洲人成在线| 免费不卡在线观看| 夜夜揉揉日日人人青青一国产精品| 日韩一本二本av| 欧美日韩一区二区三区在线看| 久久精品国产一区二区三区免费看| 国产欧美日韩精品一区| 日韩三级视频在线观看| 欧美系列在线观看| 91首页免费视频| 成人在线一区二区三区| 日韩电影在线免费观看| 一区av在线播放| 综合在线观看色| 国产嫩草影院久久久久| 欧美不卡在线视频| 91精品国产综合久久蜜臀| 色菇凉天天综合网| 91在线观看成人| 波多野结衣一区二区三区 | 国产91在线|亚洲| 免费日韩伦理电影| 人妖欧美一区二区| 蜜桃精品视频在线| 久久精品99国产国产精| 秋霞成人午夜伦在线观看| 亚洲电影在线播放| 午夜电影网亚洲视频|