成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用CSS Flexbox 構建可靠實用的網站 Header

開發 架構
在 CSS3 沒有普及的時候,創建一個網站 header 是一項既可怕又困難的任務 ?

 [[360340]]

本文已經過原作者 Shadeed 授權翻譯。

在 CSS3 沒有普及的時候,創建一個網站 header 是一項既可怕又困難的任務 ?。那時,Flexbox 還是個新東西,我們不得不使用老方法,比如 float和clearfix技術。今天,情況完全不同了,Flexbox 得到了廣泛的支持,大大的減少了我們的開發工作,同時也為我們提供了更多的可能性。

有人可能會說,現在 CSS3 這么普及,制作一個網站 header 不是很容易么 ??并非如此,因為有一些有趣的挑戰需要解決,在本文中我們會介紹其中的幾種。

簡介首先,這里所說的網站 Header 是用戶訪問網站時首先看到的內容之一。通常,它包含logo或網站名稱以及導航鏈接,如下所示:

 

不管 Header 的視覺設計如何,關鍵元素都是logo 和導航。

Flexbox

當 flexbox 應用于 Header 元素時,它將使所有子項目在同一行中。然后,你所需要做的就是應用justify-content來分配它們之間的間距。

html

 

  1. <header class="site-header"
  2.   <a href="#" class="brand">Brand</a> 
  3.   <nav class="nav"></nav> 
  4. </header> 

 

css

  1. .site-header { 
  2.   display: flex; 
  3.   justify-content: space-between
  4.   align-items: center; 

很簡單,對吧?對于這樣的用例,是的,可能會比這更復雜。

Header Wrapper

在上面的 lago 和 nav 外沒有包含一層 wrapper,這在大屏幕可能會出現問題。

 

從上可以看到第一個Header太寬了,因為它沒有內部 wrapper 相比第一個,第二個看起來好多了。所以,我們可以對 HTML 進行如下調整。

 

 

flexbox應該移動到.site-header__wrapper元素中。

  1. .site-header__wrapper { 
  2.   display: flex; 
  3.   justify-content: space-between
  4.   align-items: center; 

使用 flex-wrap當屏幕很小的時候,可以水平滾動。見下圖

 

如果沒有設置flex-wrap: wrap,當屏幕過小的時候就會出現水平滾動,如果不想這樣,可以加上 flex-wrap: wrap` ?。

Header 的多種形式

我喜歡使用flexbox的原因是它可以很容易地處理 header 設計的多種變化。基于前面的 header 設計,我擴展了 header 元素的一些選項,如添加按鈕、搜索輸入和更改子項目的順序。

Header 變化 1

 

假設我想要在導航鏈接旁邊添加了一個按鈕。這應該如何處理?我們應該把它作為鏈接添加到導航欄中嗎?還是應該和導航分開?我更喜歡這樣做。

 

 

這種情況下,我們不能在用 justify-content: space-between來處理間隙,相反,我會在 nav 元素上使用 margin-left: auto,

這樣,它就會自動向右靠齊。

 

將導航和 track 按鈕分開對于移動設備非常有用,因為我們需要保留該按鈕并在其旁邊顯示一個移動切換按鈕。

 

Header 變化 2

 

與第一個變化類似,這個變化增加了一個搜索輸入,占用了剩余的可用空間。對于flexbox,這可以通過使用flex屬性來實現。

html

  1. <header class="site-header"
  2.   <div class="wrapper site-header__wrapper"
  3.     <a href="#" class="brand"><img src="logo.svg" alt="brand" /></a> 
  4.     <div class="search"></div> 
  5.     <nav class="nav"></nav> 
  6.     <a href="/track-shipment" class="button">Track</a> 
  7.   </div> 
  8. </header> 

 

css

  1. .search { 
  2.   flex: 1; 

現在,搜索輸入將填充 brand 和nav 之間的可用空間。但是,這有一些限制。在較小的視口上,header 將如下所示:

 

搜索輸入寬度不應小于此寬度,因為這樣很難輸入和查看全文。下面有兩種解決方案:

 

我更喜歡第二種解決方案,因為它不會過早隱藏導航。一般來說,如果元素不影響布局,我會盡量避免隱藏它。

Header 變化 3

 

對于這個示例,HTML標記是相同的,但是 header 里的元素順序是不同的。我們如何才能做到這一點? 你可能想到用 order 屬性來解決這個問題 ?

html

  1. <header class="site-header"
  2.   <div class="wrapper site-header__wrapper"
  3.     <a href="#" class="brand"><img src="logo.svg" alt="brand" /></a> 
  4.     <nav class="nav"></nav> 
  5.     <a href="/track-shipment" class="button">Track</a> 
  6.   </div> 
  7. </header> 

 

css

  1. .site-header { 
  2.   display: flex; 
  3.   justify-content: space-between
  4.  
  5. .nav { 
  6.   order: -1; 

 

這樣有個問題,間隔空間不會使 logo 居中,它只是分散項目之間的空間。

解決方案是給每個子項一個flex: 1,這將在它們之間分配可用空間。

  1. .brand, 
  2. .nav, 
  3. .button { 
  4.   flex: 1; 

 

這樣,由于flex: 1,按鈕元素變寬了, 解決此問題的唯一方法是將其包裹到另一個元素中。

HTML

  1. <header class="site-header"
  2.   <div class="wrapper site-header__wrapper"
  3.     <a href="#" class="brand"><img src="logo.svg" alt="brand" /></a> 
  4.     <nav class="nav"></nav> 
  5.     <div class="button-wrapper"
  6.       <a href="/track-shipment" class="button">Track</a> 
  7.     </div> 
  8.   </div> 
  9. </header> 

 

這樣,我們就可以將下面的logo和按鈕居中。

.logo { text-align: center;}/* 不要介意這里的命名,這只是出于演示*/.button-wrapper { text-align: end; /* end 等同于LTR語言中的right */}

 

但是,如果添加了更多導航鏈接,這種方法很容易失敗。我們需要確保導航鏈接的數量不會超過特定的限制。下面一個logo偏離中心的例子 ?:

 

 


 

 

正如在上圖中看到的,logo沒有居中。所以要記住這一點,以避免這種意想不到的問題 ?。

使用 Flexbox 構建 Header 的有用技巧flex-basis

如果某個元素需要在移動設備上占據整個寬度(不能隱藏的重要導航),我會使用flex-basis: 100% ?。


 

 

從上面的模型看,做起來可能很簡單。實際上不是。通常,header 可能有一個內部間距(padding),當我們強制某項占據全部寬度時,除非清除padding ,否則它不會生效。但是,刪除padding不切實際,因為它將影響設計中的其他元素 ?。

下面解決此問題的一種解決方法 ?:

  1. 將flex: 1 0 100%添加到導航元素。
  2. 如有需要,請更改其order。有時,可能還有其他元素,我們想確保導航是最后一個。
  3. 加上一個等于寬度等于 padding 的負 margin,這也會讓導航占據整個寬度。
  4. 在導航中添加 padding,這會增加一些適當的空間。
  5. 最后,使用了justify-content: center將導航項居中(不重要)
  1. .nav { 
  2.   flex: 1 0 100%; /* [1] */ 
  3.   order: 2; /* [2] */ 
  4.   margin: 1rem -1rem -1rem -1rem; /* [3] */ 
  5.   padding: 1rem; /* [4] */ 
  6.   display: flex; /* [5] */ 
  7.   justify-content: center; /* [5] */ 

 

間距

著 Chrome 和 Firefox 支持flex gap屬性,現在在flex項目之間添加間距比以往任何時候都容易。考慮以下標題


 

 

要做到上圖的高亮間距,只需將gap: 1rem添加到flex父節點。沒有了gap,我們還是需要用舊的方式來間隔 ?。

  1. /* 老的方式 */ 
  2. .brand { 
  3.   margin-right: 1rem; 
  4.  
  5. .sign-in { 
  6.   margin-right: 1rem; 
  7.  
  8. /* 新的方式 */ 
  9. .site-header { 
  10.   /* Other flexbox styles */ 
  11.   gap: 1rem; 

作者:Shadeed 譯者:前端小智 來源:ishadeed原文:https://ishadeed.com/article/website-headers-flexbox/

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

 

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

2017-10-10 15:52:17

前端FlexboxCSS Grid

2021-10-12 15:00:00

Jekyll網站生成器開源

2017-07-10 13:09:45

前端Flexbox

2023-10-23 10:06:53

數據性能

2025-06-05 08:00:00

Go事件驅動系統編程

2023-06-01 15:14:55

架構Python微服務

2022-11-14 11:41:13

SVG開發組件

2023-02-13 15:09:01

開發webCSS技巧

2022-07-21 07:05:13

粒子動畫CSS

2010-08-24 10:26:47

DIV+CSS

2024-12-12 08:55:25

CSS代碼模式

2024-02-26 08:20:00

CSS開發

2010-08-27 10:12:53

CSS

2023-12-19 13:31:00

CSS前端技巧

2020-10-26 08:06:59

網絡技巧CSS

2024-09-18 00:00:05

Grid場景技術

2010-09-14 17:33:55

DIV+CSS布局

2010-08-16 13:46:20

DIV+CSS

2022-05-30 09:01:13

CSS技巧前端

2014-02-21 15:35:30

應用交付高頻交易
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一区二区三区不卡视频 | 欧美精品一区二区蜜桃 | 国产日韩精品视频 | 国产乱码精品一区二区三区中文 | 精品国产一区二区国模嫣然 | 亚洲在线一区二区 | 伊人免费在线观看高清 | 夜夜爽99久久国产综合精品女不卡 | 日韩免费网 | 天堂色| 日韩a | 在线观看不卡av | 3级毛片| 国产成人精品午夜视频免费 | 日本成人一区二区 | 成人影院免费视频 | 日韩国产精品一区二区三区 | 国产视频h | 日韩国产在线 | 成人久久18免费网站 | 亚洲精品自拍视频 | 日本中文字幕在线观看 | 国产一区二区三区欧美 | 欧美另类视频 | 天堂一区二区三区 | av在线播放国产 | 日韩精品区 | 久久精品一级 | 亚洲国产精品一区 | 国产精品视频导航 | 国产成人一区二区三区电影 | 日韩一区二区精品 | 99re在线视频精品 | 亚洲一区二区三区四区五区午夜 | 亚洲视频一| 久久夜色精品国产 | 国产999精品久久久久久 | 欧美一区二区免费电影 | 日韩一区二区在线免费观看 | 亚洲精品 在线播放 | 国产精品视频综合 |