国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

深入新版BS4源碼 探索flex和工程化sass奧秘

Enlightenment / 3182人閱讀

摘要:這個(gè)接受三個(gè)參數(shù)表示柵格數(shù)目默認(rèn)為默認(rèn)為表示斷點(diǎn)設(shè)置,這是一個(gè)全局變量,為類型。

你可能已經(jīng)聽說了一個(gè)“大新聞”:Bootstrap4 合并了代號為#21389的PR,宣布放棄支持IE9,并默認(rèn)使用flexbox彈性盒模型。
這標(biāo)志著:
1)前端開發(fā)全面步入“現(xiàn)代瀏覽器”的時(shí)代進(jìn)一步來臨;
2)樣式處理也再一次面向未來,擁抱更加靈活的彈性盒模型-Flex布局。

這篇文章會帶你深入Bootstrap最新版源碼,窺探其架構(gòu)組織奧秘,并解析最具亮點(diǎn)的柵格化系統(tǒng)。
同時(shí),你也會了解到sass的高階用法和flex最新語法的奧秘。

BS4的新特性

在開啟我們的探索之前,有必要先梳理一下BS4添加的新特性:
1)從Less遷移到Sass:
現(xiàn)在,Bootstrap已加入Sass的大家庭中。得益于Libsass(Sass 解析器),Bootstrap的編譯速度比以前更快;

2)改進(jìn)網(wǎng)格系統(tǒng):
新增一個(gè)網(wǎng)格層適配移動設(shè)備,并整頓語義混合。

3)默認(rèn)彈性盒模型(flexbox):
這是項(xiàng)劃時(shí)代的變動,利用flexbox的優(yōu)勢快速布局。

4)廢棄了wells、thumbnails和panels,使用cards代替。

5)新的自定義選項(xiàng):
不再像上個(gè)版本一樣,將漸變、淡入淡出、陰影等效果分放在多帶帶的樣式表中。而是將所有選項(xiàng)都移到一個(gè)Sass變量中。
想要給全局或考慮不到的角落定義一個(gè)默認(rèn)效果?很簡單,只要更新變量值,然后重新編譯就可以了。

6)使用rem和em單位。

7)重構(gòu)所有JavaScript插件:
Bootstrap 4用ES6重寫了所有插件。現(xiàn)在提供UMD支持、泛型拆解方法、選項(xiàng)類型檢查等特性。

8)改進(jìn)工具提示和popovers自動定位:
這部分要感謝Tether(A positioning engine to make overlays, tooltips and dropdowns better)工具的幫助,
如果你還不知道Tether是什么,可以去他家Github地址。

BS4柵格系統(tǒng)揭秘

了解了以上新特性,我們主要研究BS從誕生以來最大的“賣點(diǎn)”-柵格系統(tǒng)。

一個(gè)柵格實(shí)例

我們選取代表性的BS4官網(wǎng)范例,可以在線參考, 或者參看以下截圖,
在寬屏幕下,我們看到:

當(dāng)屏幕寬度小于576px時(shí)候,我們有:

對應(yīng)代碼:

...
...
...
...

.col-6 class樣式在源碼里面可以簡單歸納(不完全)為:

.col-6 {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 50%;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
}

.col-sm-3 class在源碼里面可以歸納為:

.col-sm-3{
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 25%;
        -ms-flex: 0 0 25%;
            flex: 0 0 25%;
    max-width: 25%;
}
兩種類的共存和交替作用

我們看到,代碼里設(shè)置了這兩個(gè)class進(jìn)行樣式聲明,很明顯他們的樣式屬性是有沖突的,那么他們是如何做到“和平共處”交替發(fā)揮作用的呢?

1)在屏幕寬度小于576px時(shí)候,我們發(fā)現(xiàn).col-sm-3并沒有起作用,這時(shí)候起作用的是.col-6。
我們在源碼里發(fā)現(xiàn).col-sm-*的樣式聲明全部在@media (min-width: 576px) {...}的媒體查詢中,
這就保證了在576px以下屏幕,只有在媒體查詢之外的.col-*樣式聲明發(fā)揮了作用。
2)在屏幕寬度大于576px時(shí)候,命中.col-sm-3的樣式聲明,所有他的優(yōu)先級一定大于.col-6,這時(shí)候就保證了一行四欄的樣式“占上風(fēng)”。

flex講解

我們從樣式代碼里看到類似flex: 0 0 25%的聲明,為了理解它,我們從flex屬性入手:
flex屬性是flex-grow, flex-shrink 和 flex-basis的簡寫(類似backgroud是很多背景屬性的簡寫一樣),
它的默認(rèn)值為0 1 auto。后兩個(gè)屬性可選。語法格式如下:

.item {
    flex: none | [ <"flex-grow"> <"flex-shrink">? || <"flex-basis"> ]
}

1)flex-grow:屬性定義項(xiàng)目的放大比例,默認(rèn)為0。我們看到BS代碼里這個(gè)值一直為0,即如果存在剩余空間,也不放大。

2)flex-shrink:屬性定義了項(xiàng)目的縮小比例,默認(rèn)為1,即如果空間不足,該項(xiàng)目將縮小。

3)flex-basis:屬性定義了在分配多余空間之前,項(xiàng)目占據(jù)的主軸空間(main size)。
瀏覽器根據(jù)這個(gè)屬性,計(jì)算主軸是否有多余空間。它可以設(shè)為跟width或height屬性一樣的值(比如350px),則項(xiàng)目將占據(jù)固定空間。
當(dāng)然BS4這里設(shè)置為比例值,這也是響應(yīng)式自然而然實(shí)現(xiàn)的基礎(chǔ)。

SASS在BS4工程化中的偉大作用

看到此,不難明白BS4柵格的實(shí)現(xiàn),但是這并不是此文的最終目的。我們可以深入更多,比如,BS4的柵格系統(tǒng)里,一行一共是12欄。他的媒體查詢斷點(diǎn)又包括:xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px。
參考其源碼dist/css目錄下樣式代碼,我們會想組織生成如此大量的CSS樣式,不用預(yù)處理器簡直是反人類的。而BS4卻是把sass用到了極致。

.col-sm-*是如何生成的

我們深入其scss目錄下,scss/mixins/_grid.scss文件:

@if $enable-grid-classes {
    @include make-grid-columns();
}

在enable-grid-classes變量為true的情況下(默認(rèn)為true),調(diào)用make-grid-columns()

make-grid-columns()這個(gè)mixin定義在scss/mixins/_grid-reamework.scss文件中(找的我好心累。。。):

@mixin make-grid-columns($columns: $grid-columns, $gutters: $grid-gutter-widths, $breakpoints: $grid-breakpoints) {
    ...
}

這個(gè)mixin接受三個(gè)參數(shù):
1)$columns表示柵格數(shù)目默認(rèn)為12
2)$gutters默認(rèn)為30
3)$breakpoints表示斷點(diǎn)設(shè)置,這是一個(gè)全局變量,為map類型。
這些你可以在scss/mixins/_breakpoints.scss文件中和scss/_variables.scss文件中找到。

認(rèn)識了這些參數(shù),我們看.col-sm-具體實(shí)現(xiàn),下面代碼我已經(jīng)進(jìn)行過大范圍精簡,只保留col-sm-相關(guān)部分,并且加了注釋:

@each $breakpoint in map-keys($breakpoints) {
    // Returns a blank string if smallest breakpoint, otherwise returns the name with a dash infront.
    $infix: breakpoint-infix($breakpoint, $breakpoints);
    // Media of at least the minimum breakpoint width. No query for the smallest breakpoint.
    // Makes the @content apply to the given breakpoint and wider.
    @include media-breakpoint-up($breakpoint, $breakpoints) {
        @for $i from 1 through $columns {
            .col#{$infix}-#{$i} {
                @include make-col($i, $columns);
            }
        }
    }
}

我們一步一步來分析:
1)@each $breakpoint in map-keys($breakpoints),對每一個(gè)斷點(diǎn)進(jìn)行遍歷;
2)breakpoint-infix是一個(gè)函數(shù),它定義在css/mixins/_breakpoints.scss文件當(dāng)中, 返回一個(gè)帶破折號的斷點(diǎn)標(biāo)識字符串,比如這里我們關(guān)系的就是“-sm”;
3)media-breakpoint-up是一個(gè)mixin:

@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {
    $min: breakpoint-min($name, $breakpoints);
    @if $min {
        @media (min-width: $min) {
        @content;
    }
    } @else {
        @content;
    }
}

4)breakpoint-min又是一個(gè)函數(shù),它返回了斷點(diǎn)的具體數(shù)值。這里是用來拼媒體查詢條件的。
5)最后最關(guān)鍵樣式的生成又使用了另外一個(gè)定義在css/mixins/_grid.scss文件當(dāng)中的mixin:

@mixin make-col($size, $columns: $grid-columns) {
    flex: 0 0 percentage($size / $columns);
    max-width: percentage($size / $columns);
}

到此為止,我們深入了Bootstrap V4的scss/目錄下的源碼,研究涉及了:
css/mixins/_grid-framework.scss文件;
css/mixins/_breakpoints.scss文件;
css/mixins/_grid.scss文件;
css/_variables.scss文件;
css/bootstrap-gris.scss文件;
......

如果你理解了這些,那么再去讀bootstrap新版源碼就不會存在任何難度。相信你也能夠在全局上,以“上帝視角”了解sass所起的作用,大型樣式框架的架構(gòu)組織。

總結(jié)

通過閱讀源碼的柵格系統(tǒng)部分,我們應(yīng)該認(rèn)識到sass對于這樣大型樣式框架系統(tǒng)的重要意義:
1)css模塊化在管理組織上的靈活性;
2)復(fù)用的意義,我們使用了大量的mixin,function,全局變量;
3)像JS一樣神奇的語法,包括條件、遍歷等等等等。
我們也應(yīng)該對flex這一神器有了更加深刻的認(rèn)識。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/50411.html

相關(guān)文章

  • 深入新版BS4源碼 探索flex程化sass奧秘

    摘要:這個(gè)接受三個(gè)參數(shù)表示柵格數(shù)目默認(rèn)為默認(rèn)為表示斷點(diǎn)設(shè)置,這是一個(gè)全局變量,為類型。 你可能已經(jīng)聽說了一個(gè)大新聞:Bootstrap4 合并了代號為#21389的PR,宣布放棄支持IE9,并默認(rèn)使用flexbox彈性盒模型。這標(biāo)志著:1)前端開發(fā)全面步入現(xiàn)代瀏覽器的時(shí)代進(jìn)一步來臨;2)樣式處理也再一次面向未來,擁抱更加靈活的彈性盒模型-Flex布局。 這篇文章會帶你深入Bootstrap最...

    evin2016 評論0 收藏0
  • 深入新版BS4源碼 探索flex程化sass奧秘

    摘要:這個(gè)接受三個(gè)參數(shù)表示柵格數(shù)目默認(rèn)為默認(rèn)為表示斷點(diǎn)設(shè)置,這是一個(gè)全局變量,為類型。 你可能已經(jīng)聽說了一個(gè)大新聞:Bootstrap4 合并了代號為#21389的PR,宣布放棄支持IE9,并默認(rèn)使用flexbox彈性盒模型。這標(biāo)志著:1)前端開發(fā)全面步入現(xiàn)代瀏覽器的時(shí)代進(jìn)一步來臨;2)樣式處理也再一次面向未來,擁抱更加靈活的彈性盒模型-Flex布局。 這篇文章會帶你深入Bootstrap最...

    silencezwm 評論0 收藏0
  • css - 收藏集 - 掘金

    摘要:絕對底部前端掘金來自國外的設(shè)計(jì)達(dá)人,純,可以實(shí)現(xiàn)當(dāng)正文內(nèi)容很少時(shí),底部位于窗口最下面。有效解決圖片使用單位邊角缺失的問題前端掘金起因在移動端使用布局時(shí)圖片也需要用單位。 CSS 絕對底部 - 前端 - 掘金來自國外的設(shè)計(jì)達(dá)人,純CSS,可以實(shí)現(xiàn): 當(dāng)正文內(nèi)容很少時(shí),底部位于窗口最下面。當(dāng)改變窗口高度時(shí),不會出現(xiàn)重疊問題。甚至,創(chuàng)造該CSS的人還專門成立一個(gè)網(wǎng)站介紹這個(gè)CSS底部布局方案...

    phpmatt 評論0 收藏0
  • 2017年2月份前端資源分享

    平日學(xué)習(xí)接觸過的網(wǎng)站積累,以每月的形式發(fā)布。2017年以前看這個(gè)網(wǎng)址:http://www.kancloud.cn/jsfron... 1. Javascript 前端生成好看的二維碼 十大經(jīng)典排序算法(帶動圖演示) 為什么知乎前端圈普遍認(rèn)為H5游戲和H5展示的JSer 個(gè)人整理和封裝的YU.js庫|中文詳細(xì)注釋|供新手學(xué)習(xí)使用 擴(kuò)展JavaScript語法記錄 - 掉坑初期工具 漢字拼音轉(zhuǎn)換...

    lily_wang 評論0 收藏0
  • 2017年2月份前端資源分享

    平日學(xué)習(xí)接觸過的網(wǎng)站積累,以每月的形式發(fā)布。2017年以前看這個(gè)網(wǎng)址:http://www.kancloud.cn/jsfron... 1. Javascript 前端生成好看的二維碼 十大經(jīng)典排序算法(帶動圖演示) 為什么知乎前端圈普遍認(rèn)為H5游戲和H5展示的JSer 個(gè)人整理和封裝的YU.js庫|中文詳細(xì)注釋|供新手學(xué)習(xí)使用 擴(kuò)展JavaScript語法記錄 - 掉坑初期工具 漢字拼音轉(zhuǎn)換...

    chengjianhua 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<