久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      你可能不了解的CSS容器查詢?。?/a>

      你可能不了解的CSS容器查詢??!

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

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

      當前響應設計狀態(tài)

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

      你可能不了解的CSS容器查詢??!

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

      現(xiàn)在我們來看看使用媒體查詢來看看怎么實現(xiàn)它。

      你可能不了解的CSS容器查詢??!

      上圖是同一個組件,它有三個變體,即default、CardFeatured。在CSS中,開發(fā)人員需要創(chuàng)建此組件的三個變體,其中每個組成均是唯一的。

      .c-media {   /* the default styles */   display: flex;   flex-wrap: wrap;   gap: 1rem; }  @media (min-with: 400px) {   .c-media--card {     display: block;   }    .c-media--card img {     margin-bottom: 1rem;   } }  @media (min-with: 1300px) {   .c-media--featured {     position: relative;     /* other styles */   }    .c-media--featured .c-media__content {     position: absolute;     left: 0;     top: 0;     width: 100%;     height: 100%;   } }

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

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

      你可能不了解的CSS容器查詢?。?/></p>
<p>不僅如此,當內容低于預期時,我們還會面臨一個問題。有時,UP主可能只會添加一篇文章,而設計是包含其中的三篇。在這種情況下,要么我們將有一個空的空間,要么項目將擴展以填滿可用的空間??紤]下圖:</p>
<p><img src=

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

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

      你可能不了解的CSS容器查詢?。?/></p>
<p>這樣的話,如果我們把思路轉向組件的父組件呢?換句話說,如果我們查詢父組件,并根據(jù)父組件的寬度或高度來決定組件應該是什么樣子的呢?我們來看下<strong>容器查詢</strong>的概念。</p>
<h3>什么是容器查詢</h3>
<p>首先,讓我定義容器。 它就包含另一個元素的元素,一般我們叫它 <code>wrapper</code>。</p>
<p>最新的 Chrome Canary 中,我們可以通過 chrome://flags/#enable-container-queries 開啟 Container Queries 功能。</p>
<p>當一個組件被放置在一個項中,它就被包含在該項中。這意味著,我們可以查詢父元素的寬度并據(jù)此修改它。考慮下圖</p>
<p><img src=

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

      <div class="o-grid">   <div class="o-grid__item">     <article class="c-media"></article>   </div>   <!-- + more items --> </div>

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

      .o-grid__item {   contain: layout inline-size style; }  .c-media {   /* Default style */ }  @container (min-width: 320px) {   .c-media {     /* The styles */   } }  @container (min-width: 450px) {   .c-media {     /* The styles */   } }

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

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

      你可能不了解的CSS容器查詢??!

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

      在設計時考慮容器查詢

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

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

      考慮以下設計:

      你可能不了解的CSS容器查詢?。?/></p>
<p>請注意,我們有標題、文章部分、引文和時事通訊。它們中的每一個都應該適應父視圖的寬度。</p>
<p>我可以把這些組件分成以下幾個部分</p>
<ul>
<li>Viewport (媒體查詢)</li>
<li>Parent (容器查詢)</li>
<li>通用:不受影響的組件,如按鈕、標簽、段落。</li>
</ul>
<p>對于示例UI,下面是我們如何劃分組件。</p>
<p><img src=

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

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

      你可能不了解的CSS容器查詢!!

      作為一名設計師,一開始考慮父級寬度可能有點奇怪,但這是未來的發(fā)展方向。我們?yōu)榍岸碎_發(fā)人員提供每個組件的細節(jié)和版本,他們可以使用它們。

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

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

      與開發(fā)人員溝通

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

      你可能不了解的CSS容器查詢??!

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

      在CSS網(wǎng)格中,我們可以通過使用auto-fit關鍵字告訴瀏覽器,如果列的數(shù)量低于預期,我們希望展開列(您可以在這里閱讀

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號