30 Seconds of CSS程式碼塊解讀(佈局篇)
30 Seconds of CSS程式碼塊解讀(佈局篇)
這是一個號稱在30秒內可以瞭解有用的CSS程式碼片段。GitHub地址在。由於沒有中文版,下面就記錄下所有的程式碼片段,並加上一丟丟個人見解。
這是第一篇佈局篇,主要涉及到flex和gird佈局、清除浮動、盒模型的設定等等。
Box-sizing reset
重置盒模型,防止邊框(border)和內填充(padding)影響元素寬高。
html { box-sizing: border-box; } *, *::before, *::after { box-sizing: inherit; }
說明:
box-sizing: border-box
使得新增填充或邊框不會影響元素的寬度或高度。box-sizing: inherit
繼承父元素的盒模型設定規則。(預設就是繼承,是否略微多餘?)
Clearfix
確保元素清除子元素浮動帶來的影響。該程式碼僅適用於使用了浮動的程式碼。如果可以,請使用更現代的flex
或grid
佈局。
//HTML//CSS .clearfix::after { content: ''; display: block; clear: both; } .floated { float: left; }float afloat bfloat c
說明:
.clearfix::after
定義了一個偽元素。content: ''
允許偽元素影響佈局。clear: both
指示元素的左側,右側或兩側不能與相同塊格式化上下文中較早的浮動元素相鄰。
Constant width to height ratio(寬高比恆定)
給定可變寬度的元素,讓其寬高比保持不變。
//HTML //CSS .constant-width-to-height-ratio { background: #333; width: 50%; } .constant-width-to-height-ratio::before { content: ''; padding-top: 100%; float: left; } .constant-width-to-height-ratio::after { content: ''; display: block; clear: both; }
說明:
在
::before
偽元素上使用padding-top
導致元素的高度等於其寬度的百分比。 因此100%意味著元素的高度始終為寬度的100%。::after
偽元素來清除浮動。
Evenly distributed children(均勻分佈子元素)
//HTML//CSS.evenly-distributed-children { display: flex; justify-content: space-between; }Item1
Item2
Item3
說明:
這裡使用了flex佈局。而且子元素在主軸上的分佈方式是
justify-content: space-between
。space-between
的意思是第一個元素緊靠左側,最後一個元素緊靠右側,其餘元素平分剩餘空間。主軸的另一個分佈方式還有
justify-content: space-around
,意味著左右兩側的空間是相鄰元素距離的一半,也就是圍繞(around)在父元素。
Flexbox centering
使用flex佈局讓子元素水平垂直居中。也是現在比較流行的居中方式。
//HTML//CSS.flexbox-centering { display: flex; justify-content: center; align-items: center; }Centered content.
Grid centering
使用grid佈局讓子元素水平垂直居中。同樣是比較流行的居中方式
//HTML//CSS.grid-centering { display: grid; justify-content: center; align-items: center; }Centered content.
說明:
可以發現,flex和grid的居中十分相似,除了
display
屬性值不同外,其餘都相同。但是兩者的原理是截然不同的。
Grid layout
使用gird進行佈局。(這個可不止30秒才能看完:))
//HTML//CSS .grid-layout { display: grid; grid-gap: 10px; grid-template-columns: repeat(3, 1fr); grid-template-areas: 'sidebar header header' 'sidebar content content' 'sidebar footer footer'; color: white; } .grid-layout > div { background: #333; padding: 10px; } .sidebar { grid-area: sidebar; } .content { grid-area: content; } .header { grid-area: header; } .footer { grid-area: footer; }HeaderSidebarContent
Lorem ipsum dolor sit amet, consectetur adipisicing elit.Footer
說明:
grid佈局的概念還是挺多的,建議直接google搜尋教程學習。這裡重點是透過
grid-template-columns
和grid-template-areas
進行gird佈局。
Truncate text(截斷文字)
如果文字長於一行,則它將被截斷並以省略號結束(...)。需要注意的是,只適用於單行文字。
//HTMLIf I exceed one line's width, I will be truncated.
//CSS.truncate-text { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; width: 200px; }
說明:
overflow: hidden
將超出元素寬度的文字進行隱藏。white-space: nowrap
阻止元素內的文字進行換行。text-overflow: ellipsis
超出的文字用省略號替代。
作者:坤少卡卡
連結:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/964/viewspace-2803404/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- html+css 佈局篇HTMLCSS
- CSS3 Flex 彈性佈局例項程式碼詳解CSSS3Flex
- Bootstrap柵格佈局原始碼解讀boot原始碼
- CSS3-彈性佈局篇CSSS3
- css佈局-float佈局CSS
- CSS佈局 --- 居中佈局CSS
- CSS-Flex 佈局教程:例項篇CSSFlex
- CSS-Flex 佈局教程:語法篇CSSFlex
- 詳解CSS的Flex佈局CSSFlex
- 【css】佈局CSS
- css 佈局CSS
- CSS佈局CSS
- Flutter佈局篇(1)–水平和垂直佈局詳解Flutter
- Flutter佈局篇(1)--水平和垂直佈局詳解Flutter
- CSS佈局之三欄佈局CSS
- CSS佈局 --- 自適應佈局CSS
- CSS佈局 --- 等寬&等高佈局CSS
- CSS 佈局之水平居中佈局CSS
- CSS例項詳解:Flex佈局CSSFlex
- 圖解CSS3-flex佈局圖解CSSS3Flex
- CSS 佈局模式CSS模式
- CSS 佈局模型CSS模型
- css佈局方法CSS
- css flex佈局CSSFlex
- CSS Grid 佈局CSS
- css佈局系列1——盒模型佈局CSS模型
- 微信小程式CSS之Flex佈局微信小程式CSSFlex
- CSS 佈局解決方案(終結版)CSS
- CSS 兩欄佈局和三欄佈局CSS
- CSS經典佈局——聖盃佈局與雙飛翼佈局CSS
- css居中與佈局CSS
- CSS 傳統佈局CSS
- CSS之居中佈局CSS
- css頁面佈局CSS
- CSS:兩欄佈局CSS
- CSS網格佈局CSS
- CSS基本佈局——定位CSS
- CSS display: flex佈局CSSFlex