久久精品国产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;">

      国产精品一区2区| 天天射综合影视| www.日韩av| 国产一区二区三区电影在线观看| 一区二区三区不卡视频| 中文字幕日韩一区| 亚洲欧美自拍偷拍| 国产精品大尺度| 国产精品视频第一区| 久久影院午夜片一区| 26uuu国产电影一区二区| 欧美tickle裸体挠脚心vk| 91精品啪在线观看国产60岁| 欧美性猛交xxxxxx富婆| 在线影院国内精品| 欧美人伦禁忌dvd放荡欲情| 欧美三级电影在线看| 欧美精品日韩综合在线| 日韩一区二区在线观看| 欧美精品一区二区三区在线| 久久精品综合网| 国产精品国产馆在线真实露脸 | 精品视频资源站| 欧美丝袜丝交足nylons| 91精品国产美女浴室洗澡无遮挡| 5566中文字幕一区二区电影| 欧美一区二区二区| 久久精品亚洲精品国产欧美kt∨| 国产欧美日产一区| 亚洲午夜免费视频| 国产一区二区三区综合| 97久久精品人人爽人人爽蜜臀| 欧美伊人久久大香线蕉综合69| 制服丝袜中文字幕一区| 中文字幕免费不卡| 视频一区二区不卡| 成人黄色国产精品网站大全在线免费观看| 成人国产视频在线观看| 欧美色视频在线| 久久免费视频色| 亚洲一区二区三区四区在线免费观看 | 91亚洲精品一区二区乱码| 欧美性三三影院| 日本一区二区免费在线观看视频 | 洋洋av久久久久久久一区| 蜜臀av一区二区在线免费观看| 国产99久久久国产精品潘金网站| 欧美婷婷六月丁香综合色| 久久亚洲一级片| 视频一区视频二区中文字幕| av中文字幕在线不卡| 精品久久久久久无| 舔着乳尖日韩一区| 91麻豆精品视频| 久久新电视剧免费观看| 亚洲观看高清完整版在线观看 | 精品久久久久久久人人人人传媒| 亚洲精品国产品国语在线app| 国产一区视频网站| 欧美人妇做爰xxxⅹ性高电影| 综合av第一页| 国产不卡视频一区二区三区| 欧美精品日韩精品| 亚洲一区二区三区自拍| 91视频一区二区三区| 国产三区在线成人av| 久久国产三级精品| 欧美一区二区性放荡片| 亚洲 欧美综合在线网络| 91视视频在线观看入口直接观看www | 国产亚洲欧美色| 国产美女在线观看一区| 欧美mv日韩mv亚洲| 日本成人超碰在线观看| 欧美日韩精品三区| 亚洲伊人伊色伊影伊综合网| 99国产精品久久久久| 亚洲视频1区2区| 一本色道久久综合亚洲91| 亚洲男人的天堂av| 色香蕉成人二区免费| 亚洲精品视频在线| 色94色欧美sute亚洲线路一ni| 亚洲男人的天堂在线观看| 色婷婷久久久久swag精品| 亚洲欧美另类图片小说| 色偷偷成人一区二区三区91| 亚洲免费观看视频| 一本色道**综合亚洲精品蜜桃冫 | 久久99国产精品免费网站| 日韩三级精品电影久久久| 九九视频精品免费| 日本一区二区三区国色天香| 99麻豆久久久国产精品免费| 亚洲精品高清在线| 制服丝袜av成人在线看| 国内精品免费在线观看| 国产精品亲子伦对白| 一本一道综合狠狠老| 亚洲国产日韩精品| 精品久久久久久久久久久院品网| 国产91丝袜在线播放| 亚洲欧洲日产国产综合网| 一本大道久久a久久综合| 亚洲国产一区二区a毛片| 欧美大白屁股肥臀xxxxxx| 国产在线视视频有精品| 日韩毛片在线免费观看| 欧美日产国产精品| 国产精品 日产精品 欧美精品| 亚洲美女少妇撒尿| 日韩女优视频免费观看| 北条麻妃一区二区三区| 午夜欧美2019年伦理| 欧美精品一区二区三区高清aⅴ| 国产成人精品亚洲午夜麻豆| 亚洲美女屁股眼交3| 日韩欧美一卡二卡| 色综合久久中文综合久久97| 老司机一区二区| 综合色天天鬼久久鬼色| 日韩欧美国产一区二区三区| 懂色av中文字幕一区二区三区| 亚洲男人天堂一区| 欧美成人性战久久| 色94色欧美sute亚洲线路一久| 久久成人免费网| 夜夜嗨av一区二区三区网页| 久久丝袜美腿综合| 欧美军同video69gay| aaa亚洲精品| 久久精品99国产国产精| 亚洲精品亚洲人成人网| 久久久91精品国产一区二区精品 | 在线观看精品一区| 国产91丝袜在线播放0| 日本一不卡视频| 亚洲视频一区在线| 久久久久久一二三区| 欧美老女人第四色| 色婷婷狠狠综合| 成人av资源站| 国产一区福利在线| 久久99九九99精品| 日韩电影在线观看电影| 一区二区三区日韩在线观看| 国产精品视频一二三区| 久久先锋资源网| 日韩欧美一二三四区| 欧美日韩精品高清| 在线这里只有精品| 91女神在线视频| 不卡的av电影| av中文字幕一区| 成a人片国产精品| 国产aⅴ综合色| 成人性生交大合| 成人午夜免费视频| hitomi一区二区三区精品| 国产成人av电影在线| 国内精品伊人久久久久影院对白| 免费人成精品欧美精品 | 久久久噜噜噜久噜久久综合| 日韩区在线观看| 日韩亚洲欧美在线| 精品久久一区二区| 久久久噜噜噜久久人人看| 国产欧美综合在线| 国产精品入口麻豆九色| 国产精品久久久久久久裸模| 国产精品高潮呻吟| 一区二区成人在线视频| 亚洲一卡二卡三卡四卡五卡| 亚洲乱码日产精品bd| 亚洲成a人v欧美综合天堂下载 | 国产精品99久久久久久似苏梦涵| 激情图片小说一区| 国产精品自拍av| 波多野结衣精品在线| 欧美性猛交xxxx黑人交| 337p亚洲精品色噜噜噜| 日韩精品一区国产麻豆| 国产女人18水真多18精品一级做| 国产精品国产三级国产| 一区二区三区**美女毛片| 日本成人在线一区| 成人av中文字幕| 欧美高清精品3d| 国产午夜精品美女毛片视频| 亚洲天堂网中文字| 免费的成人av| av一区二区久久| 56国语精品自产拍在线观看| 久久先锋影音av鲁色资源网| 亚洲欧美激情视频在线观看一区二区三区| 一区二区三区不卡视频在线观看| 麻豆成人在线观看| 91麻豆免费观看| 久久亚区不卡日本| 一区二区三区美女|