精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

學姐叫我看 CSS 新出的容器查詢,然后把公共組件重構成響應式的!

開發 前端
在前端開發中經常需要按不同屏幕尺寸來進設計達到PC和移動端響應式。我們一般使用CSS媒體查詢來檢測視口寬度或高度,然后根據該模式改變設計。

[[404589]]

在前端開發中經常需要按不同屏幕尺寸來進設計達到PC和移動端響應式。我們一般使用CSS媒體查詢來檢測視口寬度或高度,然后根據該模式改變設計。這就是在過去10年中設計Web布局的方式。

CSS容器查詢,一個長期以來被web開發者要求的特性,很快就會出現在CSS中,在最新的 Chrome Canary 中,我們可以通過 chrome://flags/#enable-container-queries 開啟 Container Queries 功能。在本文中,我將介紹它是什么,它將如何改變作為設計師的工作流,等等。

當前響應設計狀態

當前,我們實現響應式,一般需要 UI 設計三個樣式,分別是移動,平板電腦和桌面等。

在上圖中,UI設計了三種版本,因此開發人員可以很好的實現它,這是很 nice的(這怕偷懶的 UI 只提供PC版本,這就很蛋疼)。

現在我們來看看使用媒體查詢來看看怎么實現它。

上圖是同一個組件,它有三個變體,即default、Card和Featured。在CSS中,開發人員需要創建此組件的三個變體,其中每個組成均是唯一的。

  1. .c-media { 
  2.   /* the default styles */ 
  3.   display: flex; 
  4.   flex-wrap: wrap; 
  5.   gap: 1rem; 
  6.  
  7. @media (min-with: 400px) { 
  8.   .c-media--card { 
  9.     display: block; 
  10.   } 
  11.  
  12.   .c-media--card img { 
  13.     margin-bottom: 1rem; 
  14.   } 
  15.  
  16. @media (min-with: 1300px) { 
  17.   .c-media--featured { 
  18.     position: relative
  19.     /* other styles */ 
  20.   } 
  21.  
  22.   .c-media--featured .c-media__content { 
  23.     position: absolute
  24.     left: 0; 
  25.     top: 0; 
  26.     width: 100%; 
  27.     height: 100%; 
  28.   } 

上面的變體取決于媒體查詢或視口寬度。這意味著,我們無法根據其父寬度控制它們。現在你可能會想,這里有什么問題?喔或,這是一個很好的問題。

問題是,只有當視口寬度大于特定值時,開發人員才會使用組件的變體。例如,如果我在平板中使用 featured 也就是 PC 的樣式,它不能工作,為什么?因為它的媒體查詢寬度是大于1300px。

不僅如此,當內容低于預期時,我們還會面臨一個問題。有時,UP主可能只會添加一篇文章,而設計是包含其中的三篇。在這種情況下,要么我們將有一個空的空間,要么項目將擴展以填滿可用的空間。考慮下圖:

在第一種情況下(Case 1),文章太寬,會導致封面變形。第二種情況下(Case 2)也是一樣的問題

如果使用容器查詢,我們可以通過查詢父組件來決定如何顯示特定組件來解決這些問題。考慮下圖,它展示了我們如何使用容器查詢來修復這個問題。

這樣的話,如果我們把思路轉向組件的父組件呢?換句話說,如果我們查詢父組件,并根據父組件的寬度或高度來決定組件應該是什么樣子的呢?我們來看下容器查詢的概念。

什么是容器查詢

首先,讓我定義容器。它就包含另一個元素的元素,一般我們叫它 wrapper。

最新的 Chrome Canary 中,我們可以通過 chrome://flags/#enable-container-queries 開啟 Container Queries 功能。

當一個組件被放置在一個項中,它就被包含在該項中。這意味著,我們可以查詢父元素的寬度并據此修改它。考慮下圖

注意,每個卡片都有一個黃色的輪廓線,代表每個組件的父組件。使用CSS容器查詢,我們可以根據父組件的寬度修改組件。

  1. <div class="o-grid"
  2.   <div class="o-grid__item"
  3.     <article class="c-media"></article> 
  4.   </div> 
  5.   <!-- + more items --> 
  6. </div> 

該組件是具有類.c-media的項,它的父級是.o-grid__item元素。在CSS中,我們可以執行以下操作:

  1. .o-grid__item { 
  2.   contain: layout inline-size style; 
  3.  
  4. .c-media { 
  5.   /* Default style */ 
  6.  
  7. @container (min-width: 320px) { 
  8.   .c-media { 
  9.     /* The styles */ 
  10.   } 
  11.  
  12. @container (min-width: 450px) { 
  13.   .c-media { 
  14.     /* The styles */ 
  15.   } 

首先,我們告訴瀏覽器,每個帶有class .o-grid項的元素都是一個容器。然后,再告訴瀏覽器,如果父元素的寬度等于或大于500px,它應該以不同的方式顯示。對于700px查詢也是如此。這就是CSS容器查詢的工作原理。

此外,我們可以在任何想要的地方定義它們,這意味著如果需要,我們可以在頂級容器上進行查詢。現在大家已經理解了CSS容器查詢的基本思想,在看看下面圖片加深一下映像。

在左邊,這是一個正在調整大小的視口。在右邊,一個根據父組件寬度更改的組件。這就是容器查詢的功能和用途。

在設計時考慮容器查詢

作為一名 UI,你需要適應這個革命性的CSS特性,因為它將改變我們為網頁設計的方式。我們不僅為屏幕尺寸設計,還考慮組件在容器寬度變化時應如何適應。

現在,設計系統變得越來越流行。設計團隊將構建一組規則和組件,以便其他成員可以基于它們構建頁面。隨著CSS容器查詢的到來,我們還將設計一個組件應該如何根據其父組件的寬度進行調整。

考慮以下設計:

請注意,我們有標題、文章部分、引文和時事通訊。它們中的每一個都應該適應父視圖的寬度。

我可以把這些組件分成以下幾個部分

  • Viewport (媒體查詢)
  • Parent (容器查詢)
  • 通用:不受影響的組件,如按鈕、標簽、段落。

對于示例UI,下面是我們如何劃分組件。

當我們在設計UI時以這種心態思考時,我們可以開始考慮組件的不同變體,這些組件依賴于它們的父寬度。

在下面的圖中,請注意文章組件的每個變化是如何以特定的寬度開始的。

作為一名設計師,一開始考慮父級寬度可能有點奇怪,但這是未來的發展方向。我們為前端開發人員提供每個組件的細節和版本,他們可以使用它們。

不僅如此,我們還可能有一個組件的變體,它應該只顯示在特定的上下文中。例如,事件列表頁面。在這種情況下,清楚在何處使用此變體是很重要的。

問題是,如何告訴設計師應該在哪里使用這些組件。

與開發人員溝通

良好的溝通是項目成功的重要因素。作為一名設計人員,我們應該提供關于應該在何處使用組件變體的指導。它可以是一個完整的頁面設計,也可以是一個顯示如何使用每個組件的簡單圖。

注意我是如何將每個變體映射到一個特定的上下文,而不是一個視口。為了進一步證明這一點,我們配合 CSS網格一起使用時,組件的行為會有何不同。

在CSS網格中,我們可以通過使用auto-fit關鍵字告訴瀏覽器,如果列的數量低于預期,我們希望展開列(您可以在這里閱讀更多相關內容)。這一功能非常強大,因為它可以幫助我們在相同的背景下呈現不同的變體。

讓一個組件對它的父寬度做出反應是非常有用的。正如剛才所看到的,我們重新查看了桌面大小的頁面,并且有不同的部分,每個部分的列數不同。

在設計響應式組件時避免復雜性

重要的是要記住,組件的內部部分就像樂高游戲。我們可以根據當前的變化對它們進行排序,但所有的東西都有一個限制。有時,前端開發人員最好處理一個全新的組件,而不是使用容器查詢創建變體。

考慮以下。

它具有以下內容:

  • 頭像
  • 名稱
  • 按鈕
  • 鍵/值對

如果內部部分保持不變,或者至少不包含新的部分,我們可以改變組件,并有如下所示的多種變化。

CSS容器查詢用例

我們來探索一些可以使用CSS容器查詢實現的用例。

聊天列表

我在Facebook messenger上看到了這種模式。聊天列表根據視口寬度改變。我們可以使用CSS容器查詢來實現它。

當有足夠的空間時,清單將展開并顯示每個用戶的名稱。聊天列表的父元素可以是動態調整大小的元素(例如:使用CSS視口單元,或CSS比較函數)。

  1. // HTML 
  2. <div class="content"
  3.   <aside> 
  4.     <ul> 
  5.       <li> 
  6.         <img src="shadeed.jpg" alt="Ahmad Shadeed" /> 
  7.         <span class="name">Ahmad Shadeed</span> 
  8.       </li> 
  9.     </ul> 
  10.   </aside> 
  11.   <main> 
  12.     <h2>Main content</h2> 
  13.   </main> 
  14. </div> 
  1. // CSS 
  2. .content { 
  3.   display: grid; 
  4.   grid-template-columns: 0.4fr 1fr; 
  5.  
  6. aside { 
  7.   contain: layout inline-size style; 
  8.  
  9. @container (min-width: 180px) { 
  10.   .name { 
  11.     display: block; 
  12.   } 

aside 寬度是0.4f,所以它是動態寬度。另外,我添加了contain屬性。然后,如果容器寬度大于180px,將顯示用戶名。

另一個類似的用例是側導航。我們可以切換導航項標簽的位置,從在新行或旁邊的圖標。

當容器很小時,導航項標簽是如何從一個新行切換的,當有足夠的空間時,導航項標簽是如何靠近導航圖標的。

示例地址:https://codepen.io/shadeed/pen/Popmryw?editors=0100

~完,我是小智,我要去刷碗了,我們下期見!

作者:AAhmad Shadeed 譯者:前端小智 來源:shadeed

原文:https://ishadee.com/article/contner-queries-for-designers/

本文轉載自微信公眾號「大遷世界」,可以通過以下二維碼關注。轉載本文請聯系大遷世界公眾號。

 

責任編輯:武曉燕 來源: 大遷世界
相關推薦

2024-06-26 09:51:23

2012-12-10 10:58:02

IBMdW

2021-02-09 00:28:59

WebCSS開源

2023-11-09 16:43:38

CSS Grid網頁布局

2021-08-12 06:08:15

CSS 技巧組件狀態

2025-07-10 00:00:00

2019-11-26 10:50:47

代碼編程語言重構

2015-08-17 10:42:13

2014-12-01 11:15:40

2016-11-23 18:39:36

css

2020-09-11 09:26:55

媒體查詢HTMLCSS

2023-03-01 00:06:14

JavaScrip框架CSS

2016-12-05 19:27:37

黑科技阿迪達斯3D

2019-02-18 16:21:47

華為代碼重構

2024-11-06 10:47:53

2014-09-04 09:48:32

jQuery響應式

2011-06-02 09:47:11

C語言重構

2025-08-26 07:33:26

2024-10-14 12:56:28

2020-10-21 07:48:36

媒體查詢設計
點贊
收藏

51CTO技術棧公眾號

日韩在线观看一区二区三区| 亚洲精品国产精品国自产| 99在线观看视频免费| 中文字幕精品无码一区二区| 96视频在线观看欧美| 不卡av电影在线播放| 色婷婷av一区二区三区在线观看| 成人性色av| 任我爽在线视频| 国产综合色区在线观看| 9人人澡人人爽人人精品| 久久视频免费在线播放| 天天爽天天爽夜夜爽| 日韩欧美在线观看一区二区| 欧美国产日韩电影| 成av人片一区二区| 国产成人精品视频| 精品人妻一区二区三区日产乱码卜| 黄色免费在线观看网站| 青青草一区二区三区| 亚洲欧美第一页| 精品人妻一区二区三区四区在线 | 97精品一区二区| 欧美视频中文在线看| 精品国产综合区久久久久久| 久久久一二三区| 亚洲一区二区三区日本久久九| 亚洲男人的天堂在线aⅴ视频| 国产精品丝袜白浆摸在线| 国产精品天天干| 四虎成人在线| 五月天精品一区二区三区| 国产精品美女黄网| 精品少妇久久久久久888优播| 美女毛片一区二区三区四区| 欧美日韩亚洲系列| 欧美日韩一区二区视频在线观看| 中文字幕超碰在线| 久久99青青| 日韩欧美你懂的| 国产爆乳无码一区二区麻豆| av在线播放免费| 亚洲狼人精品一区二区三区| 精品粉嫩超白一线天av| aa视频在线播放| 日中文字幕在线| 懂色av一区二区三区免费看| 欧美大片va欧美在线播放| 国产成人精品综合久久久久99| 日韩免费影院| 9色porny自拍视频一区二区| 99久久免费国| 九九热在线免费观看| 精品理论电影| 欧美日韩一卡二卡三卡 | 亚洲精品高清在线观看| 亚洲一区精品电影| 日产精品久久久久久久| 一本色道久久综合狠狠躁的番外| 欧美日韩国产区一| 日韩久久久久久久久久久久| 91精品久久| 26uuu国产日韩综合| 国产精品青青在线观看爽香蕉| 欧美性x x x| 日本成人中文| 在线播放日韩导航| 国产一二三区在线播放| 日韩伦理av| 亚洲国产裸拍裸体视频在线观看乱了| 欧美日韩在线一二三| 三级理论午夜在线观看| 国产日韩影视精品| 成人av网站观看| 成人午夜视频一区二区播放| 日韩电影免费在线| 久久久久久亚洲精品中文字幕| 国产精品扒开腿做爽爽| 天堂精品久久久久| 欧美精品一区二区三区高清aⅴ| 国产精品一区二区无码对白| 青娱乐极品盛宴一区二区| 午夜精品aaa| 大桥未久一区二区| 蜜桃免费在线| 成人福利视频在线| 久久伦理网站| 黄色福利在线观看| 99精品国产视频| 99精品国产高清一区二区| 亚洲第一色视频| 久久精品二区亚洲w码| 欧美亚洲另类在线| 精品视频在线观看免费| 国产精品嫩草99av在线| 欧美精品久久一区二区| 在线天堂中文字幕| 精品一区二区国语对白| 国产精品www色诱视频| 国产精品一区二区6| 欧美在线三区| 久久久精品2019中文字幕神马| 欧美18—19性高清hd4k| 一区二区三区四区在线观看国产日韩| 中文字幕免费国产精品| 欧美老熟妇乱大交xxxxx| 欧美韩国日本在线观看| 欧美激情一区二区久久久| 国产成人精品777777| 国产综合一区二区| 日韩美女视频在线观看| 亚洲免费激情视频| 九九国产精品视频| 成人字幕网zmw| 亚洲在线视频播放| 看片网站欧美日韩| 精品一区二区不卡| 国产黄色小视频在线| 国产精品成人免费在线| 亚洲欧洲精品在线 | 色乱码一区二区三区在线| 竹内纱里奈兽皇系列在线观看| 亚洲国产精品人人做人人爽| 欧美日韩在线成人| 亚洲不卡系列| 亚洲丁香婷深爱综合| 喷水视频在线观看| 日韩mv欧美mv国产网站| 日韩av在线免费看| www.中文字幕av| 欧美电影一区| 国产精品美女久久久久久免费| 人人妻人人澡人人爽久久av | 亚洲av成人片色在线观看高潮| 黑色丝袜福利片av久久| 精品视频在线播放免| 日韩精品电影一区二区| 激情自拍一区| 国产成人福利视频| 黄频网站在线观看| 亚洲一区在线观看免费观看电影高清| 久久这里只有精品18| 久久影院午夜精品| 欧美一a一片一级一片| 爱豆国产剧免费观看大全剧苏畅 | 国产成人亚洲欧美| 国产欧美久久一区二区| 国内自拍在线观看| 亚洲成人三级| 亚洲伦理在线精品| jizz欧美性11| 日本不卡电影| 欧美激情视频在线| 亚洲精品成人在线视频| 日韩不卡一二三区| 欧美日韩另类综合| 超碰国产一区| 3751色影院一区二区三区| 美女av免费看| 激情欧美日韩| 国产在线精品一区二区三区| 国产三区四区在线观看| 樱桃视频在线观看一区| 岛国大片在线免费观看| 韩国一区二区三区在线观看| 日韩美女免费线视频| 日本不卡视频一区二区| 一本色道久久综合亚洲aⅴ蜜桃| 日韩精品视频一二三| 欧美顶级大胆免费视频| 亚洲综合色av| av日韩中文| 欧美日韩国产精品成人| 免费成人深夜夜行网站| 亚洲一区不卡| 欧美视频小说| 亚洲精品777| 欧美激情精品久久久久久变态| 秋霞网一区二区| 午夜影视日本亚洲欧洲精品| 亚洲自拍偷拍一区二区| 国产精品久久| 精品国产中文字幕| h1515四虎成人| 亚洲国产精品热久久| 青青青在线免费观看| 日本午夜一本久久久综合| 亚洲精品8mav| 日韩一区二区三区色| 91精品国产91久久久久福利| 国产人妻精品一区二区三区| 久久久国产一区二区三区四区小说 | 国产亚洲精品久久久久久久| 日韩精品三区| 久久视频在线直播| 亚州av在线播放| 亚洲国产视频一区二区| 一区二区黄色片| 国内久久婷婷综合| 久久免费视频3| 欧美韩国日本在线观看| 精品一区久久久久久| 欧美视频精品| 在线亚洲国产精品网| а√中文在线资源库| 亚洲日本va在线观看| 在线观看免费污视频| 国户精品久久久久久久久久久不卡| 免费亚洲精品视频| 中文在线а√在线8| 日韩中文字幕在线免费观看| 中文字幕欧美人妻精品一区蜜臀| 久久久精品黄色| wwwxxxx在线观看| 日韩精品亚洲专区| 日韩一级性生活片| 国产精品久久久久9999赢消| 成人情趣片在线观看免费| 免费网站成人| 日韩一区二区免费高清| 欧美成人aaa片一区国产精品| 国产在线播放一区| 日韩av播放器| 99久久综合| 日本精品一区二区三区高清 久久 日本精品一区二区三区不卡无字幕 | 日韩精品一区二区三区四区 | 一区二区在线观看免费视频| 国产女人18毛片水真多成人如厕| 国产成人av影视| 亚洲国产裸拍裸体视频在线观看乱了中文 | 国产suv精品一区二区三区88区| 欧美1234区| 亚洲精品久久久一区二区三区| 91精品国产色综合久久不8| 亚洲免费在线视频一区 二区| 亚洲第一综合网| 国产亚洲一二三区| 国产亚洲色婷婷久久99精品91| 国产精品99久| 丰满爆乳一区二区三区| 激情综合激情| 97视频久久久| 国产亚洲激情| 免费无码国产v片在线观看| 日韩一区二区久久| 亚洲国产欧美日韩| 国产成人调教视频在线观看| 国产精品免费网站| 日日夜夜天天综合| 欧洲中文字幕国产精品| 日本不卡在线| 日韩的一区二区| 日本美女一级片| 亚洲激情视频网| 丰满熟妇乱又伦| 亚洲成人国产精品| 亚洲成a人片在线| 日韩精品一区二区三区在线| 国产 日韩 欧美 精品| 欧美xxx久久| 国产无码精品一区二区| 粉嫩av一区二区三区| 99国产精品免费视频| 国产一区美女在线| 人人爽人人爽av| 成人午夜av影视| 97人妻精品一区二区三区免费| 成人精品一区二区三区中文字幕| 97香蕉碰碰人妻国产欧美| 97国产一区二区| 魔女鞋交玉足榨精调教| 欧美国产精品一区| 日本少妇xxx| 国产成人精品免费一区二区| 亚洲一级av无码毛片精品| 99久久精品国产观看| 免费看黄色aaaaaa 片| 亚洲国产精品二十页| 美女网站视频色| 亚洲免费观看高清完整版在线观看 | 99精品视频在线免费播放| 亚洲aⅴ日韩av电影在线观看| www.爱久久| 啪一啪鲁一鲁2019在线视频| 免费成人在线电影| 欧美亚洲激情在线| 高清一区二区| 国产极品jizzhd欧美| 久久xxx视频| 亚洲r级在线观看| 亚洲图片久久| 一区二区精品国产| 极品中文字幕一区| 久热精品在线播放| 高清久久久久久| 久久精品老司机| 亚洲欧美福利一区二区| 久久午夜免费视频| 制服视频三区第一页精品| 亚洲精品97久久中文字幕| 日韩国产精品视频| 亚洲小说区图片| 人体精品一二三区| 久久日本片精品aaaaa国产| 国产在线资源一区| 水蜜桃精品av一区二区| 久久久久久www| 久久国产视频网| 漂亮人妻被黑人久久精品| 专区另类欧美日韩| 中国毛片在线观看| 亚洲精品国产一区二区精华液| 9i看片成人免费看片| 制服丝袜亚洲精品中文字幕| 天天综合在线视频| 欧美福利视频在线| 国产极品一区| 国模精品一区二区三区| 综合在线一区| 国产情侣av自拍| 99久久婷婷国产综合精品| 翔田千里88av中文字幕| 色婷婷久久综合| 亚洲 精品 综合 精品 自拍| xvideos亚洲人网站| 亚洲精品永久免费视频| 国产98在线|日韩| 99精品视频在线观看播放| 黄色成人在线免费观看| 精品午夜久久福利影院 | 99久久精品国产毛片| 国产在线拍揄自揄拍无码视频| 欧美日韩激情一区二区| 黄色国产在线| 精品一区二区三区三区| 99自拍视频在线观看| 国产91网红主播在线观看| 亚洲国产合集| 91视频 -- 69xx| xfplay精品久久| 日韩网红少妇无码视频香港| 欧美一二三四区在线| 国产一区久久精品| 国产精品综合网站| 99re6这里只有精品| 天天干在线影院| 久久久久国产一区二区三区四区| 久草国产精品视频| 亚洲精品国产电影| 成人免费网站观看| 国产成人亚洲欧美| 在线看片成人| 菠萝菠萝蜜网站| 午夜精品一区二区三区免费视频 | 日韩视频123| av网站在线免费看推荐| 91性高湖久久久久久久久_久久99| 亚洲一级淫片| 性生活一级大片| 风间由美性色一区二区三区| wwwav国产| 欧美一区二区三区系列电影| 日本中文在线| 91久久中文字幕| 一区二区三区在线| 日本少妇一区二区三区| 伊人婷婷欧美激情| 亚洲国产av一区二区| 九九热精品视频国产| 91福利在线免费| 欧美一区1区三区3区公司| 久久xxxx| 中文字幕一区二区三区人妻在线视频 | 亚洲综合20p| 91麻豆文化传媒在线观看| 亚洲另类欧美日韩| 国产亚洲福利一区| 日韩色性视频| 久久99久久99精品| 久久色成人在线| 亚洲一区 欧美| 日韩一区二区三区免费看| 欧美hdxxx| 高清视频一区| 老鸭窝毛片一区二区三区| 美国一级黄色录像| 欧美精品一区二区三| 免费电影日韩网站| 国产日本欧美在线| 不卡欧美aaaaa| 国产成人精品网| 久久99久国产精品黄毛片入口| 国产精品视频3p| 国产高清精品软男同| 国产91丝袜在线播放| 69成人免费视频| 欧美丰满老妇厨房牲生活| 蜜桃精品噜噜噜成人av| 风韵丰满熟妇啪啪区老熟熟女| 日韩欧美在线观看|