自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用CSS Flexbox 構(gòu)建可靠實(shí)用的網(wǎng)站 Header

開發(fā) 架構(gòu)
在 CSS3 沒有普及的時(shí)候,創(chuàng)建一個(gè)網(wǎng)站 header 是一項(xiàng)既可怕又困難的任務(wù) ?

 [[360340]]

本文已經(jīng)過原作者 Shadeed 授權(quán)翻譯。

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

有人可能會(huì)說,現(xiàn)在 CSS3 這么普及,制作一個(gè)網(wǎng)站 header 不是很容易么 ??并非如此,因?yàn)橛幸恍┯腥さ奶魬?zhàn)需要解決,在本文中我們會(huì)介紹其中的幾種。

簡(jiǎn)介首先,這里所說的網(wǎng)站 Header 是用戶訪問網(wǎng)站時(shí)首先看到的內(nèi)容之一。通常,它包含logo或網(wǎng)站名稱以及導(dǎo)航鏈接,如下所示:

 

不管 Header 的視覺設(shè)計(jì)如何,關(guān)鍵元素都是logo 和導(dǎo)航。

Flexbox

當(dāng) flexbox 應(yīng)用于 Header 元素時(shí),它將使所有子項(xiàng)目在同一行中。然后,你所需要做的就是應(yīng)用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; 

很簡(jiǎn)單,對(duì)吧?對(duì)于這樣的用例,是的,可能會(huì)比這更復(fù)雜。

Header Wrapper

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

 

從上可以看到第一個(gè)Header太寬了,因?yàn)樗鼪]有內(nèi)部 wrapper 相比第一個(gè),第二個(gè)看起來好多了。所以,我們可以對(duì) HTML 進(jìn)行如下調(diào)整。

 

 

flexbox應(yīng)該移動(dòng)到.site-header__wrapper元素中。

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

使用 flex-wrap當(dāng)屏幕很小的時(shí)候,可以水平滾動(dòng)。見下圖

 

如果沒有設(shè)置flex-wrap: wrap,當(dāng)屏幕過小的時(shí)候就會(huì)出現(xiàn)水平滾動(dòng),如果不想這樣,可以加上 flex-wrap: wrap` ?。

Header 的多種形式

我喜歡使用flexbox的原因是它可以很容易地處理 header 設(shè)計(jì)的多種變化?;谇懊娴?header 設(shè)計(jì),我擴(kuò)展了 header 元素的一些選項(xiàng),如添加按鈕、搜索輸入和更改子項(xiàng)目的順序。

Header 變化 1

 

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

 

 

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

這樣,它就會(huì)自動(dòng)向右靠齊。

 

將導(dǎo)航和 track 按鈕分開對(duì)于移動(dòng)設(shè)備非常有用,因?yàn)槲覀冃枰A粼摪粹o并在其旁邊顯示一個(gè)移動(dòng)切換按鈕。

 

Header 變化 2

 

與第一個(gè)變化類似,這個(gè)變化增加了一個(gè)搜索輸入,占用了剩余的可用空間。對(duì)于flexbox,這可以通過使用flex屬性來實(shí)現(xiàn)。

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; 

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

 

搜索輸入寬度不應(yīng)小于此寬度,因?yàn)檫@樣很難輸入和查看全文。下面有兩種解決方案:

 

我更喜歡第二種解決方案,因?yàn)樗粫?huì)過早隱藏導(dǎo)航。一般來說,如果元素不影響布局,我會(huì)盡量避免隱藏它。

Header 變化 3

 

對(duì)于這個(gè)示例,HTML標(biāo)記是相同的,但是 header 里的元素順序是不同的。我們?nèi)绾尾拍茏龅竭@一點(diǎn)? 你可能想到用 order 屬性來解決這個(gè)問題 ?

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; 

 

這樣有個(gè)問題,間隔空間不會(huì)使 logo 居中,它只是分散項(xiàng)目之間的空間。

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

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

 

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

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語(yǔ)言中的right */}

 

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

 

 


 

 

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

使用 Flexbox 構(gòu)建 Header 的有用技巧flex-basis

如果某個(gè)元素需要在移動(dòng)設(shè)備上占據(jù)整個(gè)寬度(不能隱藏的重要導(dǎo)航),我會(huì)使用flex-basis: 100% ?。


 

 

從上面的模型看,做起來可能很簡(jiǎn)單。實(shí)際上不是。通常,header 可能有一個(gè)內(nèi)部間距(padding),當(dāng)我們強(qiáng)制某項(xiàng)占據(jù)全部寬度時(shí),除非清除padding ,否則它不會(huì)生效。但是,刪除padding不切實(shí)際,因?yàn)樗鼘⒂绊懺O(shè)計(jì)中的其他元素 ?。

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

  1. 將flex: 1 0 100%添加到導(dǎo)航元素。
  2. 如有需要,請(qǐng)更改其order。有時(shí),可能還有其他元素,我們想確保導(dǎo)航是最后一個(gè)。
  3. 加上一個(gè)等于寬度等于 padding 的負(fù) margin,這也會(huì)讓導(dǎo)航占據(jù)整個(gè)寬度。
  4. 在導(dǎo)航中添加 padding,這會(huì)增加一些適當(dāng)?shù)目臻g。
  5. 最后,使用了justify-content: center將導(dǎo)航項(xiàng)居中(不重要)
  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屬性,現(xiàn)在在flex項(xiàng)目之間添加間距比以往任何時(shí)候都容易??紤]以下標(biāo)題


 

 

要做到上圖的高亮間距,只需將gap: 1rem添加到flex父節(jié)點(diǎn)。沒有了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/

 本文轉(zhuǎn)載自微信公眾號(hào)「大遷世界」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系大遷世界公眾號(hào)。

 

責(zé)任編輯:武曉燕 來源: 大遷世界
相關(guān)推薦

2017-10-10 15:52:17

前端FlexboxCSS Grid

2021-10-12 15:00:00

Jekyll網(wǎng)站生成器開源

2017-07-10 13:09:45

前端Flexbox

2023-10-23 10:06:53

數(shù)據(jù)性能

2023-06-01 15:14:55

架構(gòu)Python微服務(wù)

2022-11-14 11:41:13

SVG開發(fā)組件

2023-02-13 15:09:01

開發(fā)webCSS技巧

2022-07-21 07:05:13

粒子動(dòng)畫CSS

2010-08-24 10:26:47

DIV+CSS

2024-12-12 08:55:25

CSS代碼模式

2010-08-27 10:12:53

CSS

2023-12-19 13:31:00

CSS前端技巧

2024-02-26 08:20:00

CSS開發(fā)

2020-10-26 08:06:59

網(wǎng)絡(luò)技巧CSS

2024-09-18 00:00:05

Grid場(chǎng)景技術(shù)

2010-09-14 17:33:55

DIV+CSS布局

2010-08-16 13:46:20

DIV+CSS

2012-12-10 10:58:02

IBMdW

2021-05-11 08:30:54

前端css技術(shù)熱點(diǎn)

2023-07-24 15:24:00

前端CSS 技巧
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)