Am i center?
Center me ,please!
摘要:當列表中至少包含四項時,命中包括該項之后的所有列表項當然,不止于此,的玩法完全取決于你的腦洞。而且絕對定位對整個布局的影響也太過強烈。如此,對于響應布局也可以不用擔心了,雖然有點點,但也算完美的解決了,
title: 結(jié)構(gòu)與布局
date: 2016-12-11
tags: CSS Secrets
CSS3 新增寬度屬性值 width:min-content 可以將容器的寬度值設置為容器內(nèi)最大的不可斷行的寬度(最寬的單詞,圖片,或者具有固定寬度的盒元素)
figure{ width:min-content; margin: auto; }0x01 根據(jù)兄弟元素的數(shù)量來設置樣式
我們知道偽元素選擇器 :only-child,其實,它可以等效于:first-child:last-child,即是第一項的同時也是最后一項,所以從邏輯上來講它是唯一的。而:last-child 也是:nth-last-child(1)的快捷寫法。
那么接下來思考一個問題,li:first-chidl:nth-last-child(4) 代表什么?結(jié)果是 _一個正好有四個列表項的列表中的第一項_,ok,再結(jié)合兄弟選擇符~來命中它之后的每一項,就可以達到這樣一個目標在正好包含四個列表項的時候,命中它的每一項
li:first-child:nth-last-child(4), li:first-child:nth-last-child(4) ~ li { background: red; }
結(jié)合 SASS,將其簡化復用
/*定義混合器*/ @mixin n-items($n){ &:first-child:nth-last-child(#{$n}), &:first-child:nth-last-child(#{$n}) ~ &{ @content; } } /*調(diào)用*/ li { @include n-items(4){ /*屬性與值寫在這里*/ background: red; } }:nth-child()
nth-child()的強大之處在于以接受an+b形式的表達式,那么自然便可以使用其變種 nth-child(n+4) 這種形式,它將會選擇除了第1,2,3個子元素之外的所有子元素。
ul li:first-child:nth-last-child(n+4), ul li:first-child:nth-last-child(n+4) ~ li{ /*當列表中至少包含四項時,命中包括該項之后的所有列表項*/ }
當然,不止于此,:nth-child()的玩法完全取決于你的腦洞。
0x02 calc有時,若需要去實現(xiàn)一個 背景寬度滿屏,內(nèi)容寬度固定 的布局,也許我們會去這樣設計 DOM 結(jié)構(gòu)
CSS 樣式:
footer{ background: #333; } .wrapper{ max-width: 900px; margin: 1em auto; height: 200px; }
使用 calc() 方法以后,就不必如此麻煩了,我們只需三行代碼即可實現(xiàn):
footer{ background:#333; padding:1em calc(50% - 50px); }
使用了 clac() 便可以在 CSS 中進行簡單的算術(shù)運行,這使得 DOM 結(jié)構(gòu)變得非常簡潔,沒有任何的冗余,當然,缺點也是顯而易見的,這里的代碼只會在 footer 元素的父級超過 900 px 才會看出效果。
calc() 中的百分比是基于其父級進行解析的
但,我們初次了解到了CSS3 中cacl() 這個魔法技巧。
0x03 垂直居中 基于絕對定位的解決方案CSS 中有一個很常見的現(xiàn)象,真正的解決方法往往來自于我們最意想不到的地方。比如,可以結(jié)合 positon:absolute 和 transform:translate() 屬性來實現(xiàn)垂直居中
因為 translate() 變形函數(shù)中的百分比是根據(jù)這個元素自身的寬度和高度為基準進行換算的,如此一來,便可以徹底解除對固定尺寸的依賴。
示例:DOM 結(jié)構(gòu)
Am i center?
Center me ,please!
CSS代碼:
.main{ position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); }
不過,該方法也是存在不足的:
1.在某些瀏覽器中,可能會導致模糊顯示,因為元素有可能被放置在半個像素上。
2.在并不適合使用絕對定位的情況下。而且絕對定位對整個布局的影響也太過強烈。
毫無疑問,這算是目前最佳的解決方案了。并且,現(xiàn)代瀏覽器對 FlexBox 的支持已經(jīng)相當高了。
對基于 FlexBox 容器的 items 使用 margin:auto 不僅可以在水平方向方居中,垂直方向上亦是如此,即使不指定任何寬度,因為這個元素分配到的寬度等于 max-content.
FlexBox 的另一個好處是可以文本也進行垂直居中, 只需對使用display:flex 的元素添加 align-items:center 和 justify-content:center。
.main{ background: deeppink; width: 50%; height: 50%; margin: auto; display: flex; align-items: center; justify-content: center; }0x04 緊貼底部的頁腳
有時,我們期望頁頭和頁腳的高度由其內(nèi)部因素來決定,而內(nèi)容區(qū)塊的高度可以自動收縮并占滿所有可用的空間。同樣,利用 FlexBox 這很容易。
body { min-height: 100vh; display:flex; flex-flow: column; header{ /*heaer style*/ } .main{ flex:1; } footer{ /*footer style*/ } }
我們給了 body 一個 min-height:100vh 的高度這樣它至少會占據(jù)整個視口的高度,然后賦予 main 一個大于 0 的 flex 值就可以了。
問題:如果頁腳是固定在屏幕的底部的呢?如何解決當頁面滾動到最后的時候保證頁腳不會覆蓋內(nèi)容區(qū)?
對于這個問題,純屬個人想法,可以在 footer 之后添加一個 div#_footer。
此時的 DOM 結(jié)構(gòu)如下:
而對于 div#_footer 而言,不需要為其中添加任何的內(nèi)容和樣式,只需要它的高度等于 footer 的高度就可以了,而對于這點,使用 jQuery 就可以輕松搞定。
$("#_footer").height($("footer").height())
如此,對于響應布局也可以不用擔心了,雖然有點點hack,但也算完美的解決了,Bingo!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91322.html
摘要:網(wǎng)格單元格網(wǎng)格單元格是指四條網(wǎng)格線之間的空間。所以它是最小的單位,就像表格中的單元格。圖中突出顯示的網(wǎng)格區(qū)域是行線和列線之間的區(qū)域,其主要包括了四個網(wǎng)格單元格。 CSS Grid現(xiàn)在已經(jīng)被W3C納入到CSS3的一個布局模塊當中,被稱為CSS Grid Layout Module。而我們較為熟悉的還是將其想像成網(wǎng)格或者柵格,也就是早期的960gs。不管是網(wǎng)格還是柵格或者現(xiàn)在的CSS Gr...
摘要:由一道面試題引發(fā)的思考從用戶輸入瀏覽器輸入到頁面最后呈現(xiàn)有哪些過程一道很常規(guī)的題目,考的是基本網(wǎng)絡原理,和瀏覽器加載,過程。所以抽出時間研究下瀏覽器渲染頁面的過程。 由一道面試題引發(fā)的思考: 從用戶輸入瀏覽器輸入url到頁面最后呈現(xiàn) 有哪些過程?一道很常規(guī)的題目,考的是基本網(wǎng)絡原理,和瀏覽器加載css,js過程。 答案大致如下: 用戶輸入URL地址 瀏覽器解析URL解析出主機名 瀏覽...
摘要:當列表中至少包含四項時,命中包括該項之后的所有列表項當然,不止于此,的玩法完全取決于你的腦洞。而且絕對定位對整個布局的影響也太過強烈。如此,對于響應布局也可以不用擔心了,雖然有點點,但也算完美的解決了, title: 結(jié)構(gòu)與布局date: 2016-12-11tags: CSS Secrets 0x00 min-content 寬度自適應 CSS3 新增寬度屬性值 width:mi...
摘要:當列表中至少包含四項時,命中包括該項之后的所有列表項當然,不止于此,的玩法完全取決于你的腦洞。而且絕對定位對整個布局的影響也太過強烈。如此,對于響應布局也可以不用擔心了,雖然有點點,但也算完美的解決了, title: 結(jié)構(gòu)與布局date: 2016-12-11tags: CSS Secrets 0x00 min-content 寬度自適應 CSS3 新增寬度屬性值 width:mi...
摘要:代碼如下頁面內(nèi)容樣式接下來,將側(cè)邊欄和主內(nèi)容區(qū)域使用一個包含起來。列和行布局部分橫跨所有的列。也可以使用簡寫,起始值和結(jié)束值位于同一行上,并用斜杠分隔。設計方法總結(jié)以上的布局設計中,使用了來進行整體布局以及設計中的非線性部分。 CSS 浮動屬性一直是網(wǎng)站上排列元素的主要方法之一,但是當實現(xiàn)復雜布局時,這種方法不總是那么理想。幸運的是,在現(xiàn)代網(wǎng)頁設計時代,使用 Flexbox 和 CSS...
閱讀 3431·2021-10-20 13:49
閱讀 2806·2021-09-29 09:34
閱讀 3701·2021-09-01 11:29
閱讀 3087·2019-08-30 11:01
閱讀 849·2019-08-29 17:10
閱讀 886·2019-08-29 12:48
閱讀 2788·2019-08-29 12:40
閱讀 1361·2019-08-29 12:30