如何高效地定制你的bootstrap

2018-09-10 17:05 更新
bootstrap 已經(jīng)作為前端開發(fā)必不可少的框架之一,應(yīng)用bootstrap使得我們對(duì)布局、樣式的設(shè)定變得非常簡(jiǎn)單。

但bootstrap提供的默認(rèn)樣式往往不能滿足我們的需求,從而定制化bootstrap成為我們經(jīng)常需要做的工作,本文就如何更高效更可維護(hù)地定制bootstrap做一下探討。

如下圖,在你的button 中加入bootstrap的class: btn btn-primary,就可以將默認(rèn)的button(左邊)變成右邊的樣式。

定制bootstrap

可如果我們想應(yīng)用自己的樣式呢?比如我們想要擁有圓角的button。

通常,我們可以直接覆蓋bootstrap的樣式。

我們?cè)谧约旱捻?xiàng)目目錄下新建my-custom.css文件,加入如下代碼:

.btn {
   -webkit-border-radius: 20px;
   -moz-border-radius: 20px;
   border-radius: 20px;
}
將my-custom.css文件引用放到bootstrap.css文件后面,我們定義的btn樣式就會(huì)覆蓋原有的樣式(注:這里的‘覆蓋’指的是增量疊加式的覆蓋)。
<link rel="stylesheet" href="boostrap.css">
<link rel="stylesheet" href="my-custom.css">
但這種方法有它的優(yōu)缺點(diǎn),

優(yōu)點(diǎn):不會(huì)改變你的工作流程。你可以快速直接修改你的樣式,即使是你的網(wǎng)站引用了其他的類似bootstrap的框架樣式,你都可以在同一個(gè)地方進(jìn)行統(tǒng)一的定制。

缺點(diǎn):但是對(duì)于更徹底的修改(比如重新設(shè)計(jì)導(dǎo)航欄)或是非局部的修改(比如修改適用于整個(gè)網(wǎng)站的高亮顏色)來說,這樣?xùn)|一塊,西一塊的覆蓋樣式更像是一種打補(bǔ)丁式的解決方案。而且你的新樣式要添加到Bootstrap的默認(rèn)樣式表里,讓本已經(jīng)100 KB的文件越發(fā)臃腫。如果你不僅僅想要做一些覆蓋,那就要考慮一種更具擴(kuò)展性的方法了。

另一種方法是生成一個(gè)自定義構(gòu)建的bootstrap。

我們可以使用官方的 構(gòu)建器 ,你可以對(duì)bootstrap中樣式變量進(jìn)行自定義。如下圖所示:


自定義構(gòu)建bootstrap


bootstrap 是基于less定制的,如果你不熟悉less語(yǔ)法,建議到其官網(wǎng)( http://lesscss.org/ )或者中文網(wǎng)( http://less.bootcss.com/ http://www.bootcss.com/p/lesscss/ )學(xué)習(xí)一下,很簡(jiǎn)單,了解并學(xué)會(huì)使用它用不了多長(zhǎng)時(shí)間。

定制好你的變量后點(diǎn)擊download按鈕就會(huì)生成一套屬于你的bootstrap框架了。

當(dāng)然,這種方法也有它的優(yōu)缺點(diǎn),

優(yōu)點(diǎn):相比上一種方法,它簡(jiǎn)便了你對(duì)整體網(wǎng)站的修改。

缺點(diǎn):首先你很難一開始就確定網(wǎng)站所有的樣式風(fēng)格,當(dāng)然你可以在確定好了后再生成一個(gè)最終版本。所以這就引入一個(gè)問題,如果你還要時(shí)不時(shí)更換你的樣式,你同樣需要找到bootstrap樣式源文件編輯,你可能還要用到第一種方法,比如我要使用圓角的帶陰影的button,光定制就不能滿足我的需求,再者,如果面對(duì)bootstrap升級(jí)的問題,你還需要重新根據(jù)你的樣式構(gòu)建一個(gè)新版本的bootstrap,這樣要真的做起來,會(huì)非常的麻煩。

最后一種方法是深度定制bootstrap less

首先獲得bootstrap的 源碼 ,

打開源碼,你會(huì)發(fā)現(xiàn)Bootstrap的樣式是用 LESS 而不是CSS寫的。LESS 是一種動(dòng)態(tài)樣式表語(yǔ)言,相比于CSS,它支持多種 優(yōu)秀特性 ,包括選擇器嵌套,創(chuàng)建變量(就像在上面生成器中使用的)。一旦寫完,你可以選擇將LESS代碼預(yù)先或在運(yùn)行時(shí)編譯成 CSS。如果你喜歡 Sass,可以使用這個(gè)適用于 Sass的Bootstrap 。

在 less 文件夾中,你會(huì)看到許多按照組件來劃分的 LESS 文件。


深度定制bootstrap less


我們打開bootstrap.less文件看看里面寫的是什么:

 1 // Core variables and mixins
 2 @import "variables.less";
 3 @import "mixins.less";
 4 
 5 // Reset and dependencies
 6 @import "normalize.less";
 7 @import "print.less";
 8 @import "glyphicons.less";
 9 
10 // Core CSS
11 @import "scaffolding.less";
12 @import "type.less";
13 @import "code.less";
14 @import "grid.less";
15 @import "tables.less";
16 @import "forms.less";
17 @import "buttons.less";
18 
19 // Components
20 @import "component-animations.less";
21 @import "dropdowns.less";
22 @import "button-groups.less";
23 @import "input-groups.less";
24 @import "navs.less";
25 @import "navbar.less";
26 @import "breadcrumbs.less";
27 @import "pagination.less";
28 @import "pager.less";
29 @import "labels.less";
30 @import "badges.less";
31 @import "jumbotron.less";
32 @import "thumbnails.less";
33 @import "alerts.less";
34 @import "progress-bars.less";
35 @import "media.less";
36 @import "list-group.less";
37 @import "panels.less";
38 @import "responsive-embed.less";
39 @import "wells.less";
40 @import "close.less";
41 
42 // Components w/ JavaScript
43 @import "modals.less";
44 @import "tooltip.less";
45 @import "popovers.less";
46 @import "carousel.less";
47 
48 // Utility classes
49 @import "utilities.less";
50 @import "responsive-utilities.less";


View Code
實(shí)際上,bootstrap是通過編譯bootstrap.less這一個(gè)文件而生成整個(gè)bootstrap.css文件的。我們看到bootstrap.less的作用僅僅是引入其他文件。這樣,我們定制化的工作就好辦了。

以下這些文件是你要注意的:

bootstrap.less:

這個(gè)是核心文件。它用來引入其他文件,最終由你來編譯它。


reset.less:

始終是最先引入的文件。


variables.less 和 mixins.less:

這兩個(gè)文件總是同時(shí)出現(xiàn),因?yàn)槠渌募家蕾囉谒鼈?。前一個(gè)文件包含了在生成器網(wǎng)站上使用的相同的變量。


utilities.less:
這個(gè)文件總是最后引入,你可以把想要覆蓋的類寫到這里。
我們定制的思路就是,找到我們需要定制的組件和相對(duì)應(yīng)的變量,對(duì)其修改,然后編譯成我們自己的bootstrap.css即可。

下面講講具體實(shí)現(xiàn)方法。

確保你已經(jīng) 安裝好Less , 為了不讓我們修改的內(nèi)容與原始文件重合在一起,我們需要模塊化的修改。

首先下載bootstrap源碼,下載后就不需要對(duì)其做任何的改動(dòng)了。我們單獨(dú)建立一個(gè)文件夾(文件目錄只要能引用到bootstrap的less文件就可以),取名為custom-bootstrap,其中包含以下三個(gè)文件:

custom-variables.less:

這個(gè)文件包含你要定制的變量。

custom-other.less:

這個(gè)文件中包含了那些無法通過修改變量完成定制的內(nèi)容,比如增加或禁用button的text-shandow屬性。

custom-bootstrap.less

這是新的「核心」文件。我們將把它編譯成CSS。與原始的 LESS文件一樣,它使用下面的命令來引入上面那兩個(gè)自定義文件(記住要保證文件正確的引用順序)
@import "../bootstrap/less/bootstrap.less"; //這個(gè)引用到原有的bootstrap文件
@import "custom-variables.less"; 
@import "custom-other.less";   
@import "../bootstrap/less/utilities.less"; //我們同樣要引用原生的utilities.less,因?yàn)槲覀円WC該文件始終最后一個(gè)被導(dǎo)入
這時(shí),我們只要編譯custom-bootstrap.less就可以了。

有一些需要注意的是,custom-variables.less 不需要拷貝原有文件的所有內(nèi)容,只需要拷貝和你要定制的組件相關(guān)的變量就可以了,如果你這樣做了,單獨(dú)編譯custom-variables.less或custom-other.less會(huì)提示缺少變量定義的錯(cuò)誤,但這沒關(guān)系,你只要保證編譯 custom-bootstrap.less 沒有錯(cuò)誤就可以了。

這種方法的優(yōu)點(diǎn)在于,將定制的變化與原有庫(kù)代碼很好的隔離,卻又不失可維護(hù)性。即使今后升級(jí)bootstrap版本,我們也不要擔(dān)心重新構(gòu)建樣式框架了。


如何更高效的定制bootstrap還有一點(diǎn)需要注意的就是,你要理解bootstrap組織代碼的方式以及如果更高效的書寫Less。
以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)