很早之前就聽說過less了,但是一直拖著沒去學習。最近抽空看了less,其實語法很簡單,看一遍基本就知道怎麼用了。但是問題又來了,那我在什麼時候用less呢。平時自己寫頁面用less的話,感覺是方便了些,但是難道好處就只是這樣?
剛好最近也在學習bootstrap,發現其源文件就是用less寫的,看了之後,我才深深體會的less的強大,對less也有了更深一層的理解。
1、Less是什麼?
LESS CSS是一種動態樣式語言,屬於CSS預處理語言的一種,它使用類似CSS的語法,為CSS的賦予了動態語言的特性,如變量、繼承、運算、函數等,更方便CSS的編寫和維護。
有些人可能沒有接觸過less,那我們就先可以簡單的看看less的一些特性。
2、語言特性快速預覽:
變量:
變量允許我們單獨定義一系列通用的樣式,然後在需要的時候去調用。所以在做全局樣式調整的時候我們可能只需要修改幾行代碼就可以了。
LESS源碼:
@color: #4D926F; #header { color: @color; } h2 { color: @color; }
編譯後的CSS:
#header { color: #4D926F; } h2 { color: #4D926F; }
混合(Mixins)
混合可以將一個定義好的class A輕松的引入到另一個class B中,從而簡單實現class B繼承class A中的所有屬性。我們還可以帶參數地調用,就像使用函數一樣。
LESS源碼:
.rounded-corners (@radius: 5px) { -webkit-border-radius: @radius; -moz-border-radius: @radius; -ms-border-radius: @radius; -o-border-radius: @radius; border-radius: @radius; } #header { .rounded-corners; } #footer { .rounded-corners(10px); }
編譯後的CSS:
#header { -webkit-border-radius: 5px; -moz-border-radius: 5px; -ms-border-radius: 5px; -o-border-radius: 5px; border-radius: 5px; } #footer { -webkit-border-radius: 10px; -moz-border-radius: 10px; -ms-border-radius: 10px; -o-border-radius: 10px; border-radius: 10px; }
嵌套
我們可以在一個選擇器中嵌套另一個選擇器來實現繼承,這樣很大程度減少了代碼量,並且代碼看起來更加的清晰。
LESS源碼:
#header { h1 { font-size: 26px; font-weight: bold; } p { font-size: 12px; a { text-decoration: none; &:hover { border-width: 1px } } } }
編譯後的CSS:
#header h1 { font-size: 26px; font-weight: bold; } #header p { font-size: 12px; } #header p a { text-decoration: none; } #header p a:hover { border-width: 1px; }
函數和運算
運算提供了加,減,乘,除操作;我們可以做屬性值和顏色的運算,這樣就可以實現屬性值之間的復雜關系。LESS中的函數一一映射了JavaScript代碼,如果你願意的話可以操作屬性值。
LESS源碼:
@the-border: 1px; @base-color: #111; @red: #842210; #header { color: (@base-color * 3); border-left: @the-border; border-right: (@the-border * 2); } #footer { color: (@base-color + #003300); border-color: desaturate(@red, 10%); }
編譯後的CSS:
#header { color: #333; border-left: 1px; border-right: 2px; } #footer { color: #114411; border-color: #7d2717; }
想具體學習less,可以訪問 http://www.1024i.com/demo/less/document.html
3、bootstrap中less的使用
下載 Bootstrap,解壓縮文件。Bootstrap 的 Less 組件位於less目錄下,其中包含至少20多個less文件,那為什麼要分成這麼多個呢?主要是方便開發,後期也便於維護,另外就是便於用戶修改樣式。
開發人員在編寫樣式的時候,首先對頁面的元素和作用效果進行分離,比如form,button,responsive,tables等等。然後分別編寫,雖然是獨立編寫,但是有些樣式是全局要用的,比如提醒的顏色,頁面的背景色都是同一種。但是less文件很可能是多個人同時編寫的,那怎麼來確保樣式的統一呢。這時候,less的作用就顯現出來了。
我們可以看看 variables.less 文件裡的內容,下面節選了一部分:
// Grays // ------------------------- @black: #000; @grayDarker: #222; @grayDark: #333; @gray: #555; @grayLight: #999; @grayLighter: #eee; @white: #fff; /* .........省略部分..................... */ // Typography // ------------------------- @sansFontFamily: "Helvetica Neue", Helvetica, Arial, sans-serif; @serifFontFamily: Georgia, "Times New Roman", Times, serif; @monoFontFamily: Monaco, Menlo, Consolas, "Courier New", monospace; @baseFontSize: 14px; @baseFontFamily: @sansFontFamily; @baseLineHeight: 20px; @altFontFamily: @serifFontFamily; @headingsFontFamily: inherit; // empty to use BS default, @baseFontFamily @headingsFontWeight: bold; // instead of browser default, bold @headingsColor: inherit; // empty to use BS default, @textColor
從上面可以看出,開發人員已經為一些常用的樣式變成變量的形式。並且每一個變量的名字都很具體,只要一看就知道這是要設置什麼。那具體是怎樣用的呢?我們來看看buttons.less文件,同樣是節選部分:
// Base styles // -------------------------------------------------- // Core .btn { display: inline-block; .ie7-inline-block(); padding: 4px 12px; margin-bottom: 0; // For input.btn font-size: @baseFontSize; line-height: @baseLineHeight; text-align: center; vertical-align: middle; cursor: pointer; .buttonBackground(@btnBackground, @btnBackgroundHighlight, @grayDark, 0 1px 1px rgba(255,255,255,.75)); border: 1px solid @btnBorder; *border: 0; // Remove the border to prevent IE7's black border on input:focus border-bottom-color: darken(@btnBorder, 10%); .border-radius(@baseBorderRadius); .ie7-restore-left-whitespace(); // Give IE7 some love .box-shadow(~"inset 0 1px 0 rgba(255,255,255,.2), 0 1px 2px rgba(0,0,0,.05)");
怎麼樣,是不是很方便。媽媽再也不用擔心我傻傻寫錯樣式了。上面只是列舉了了變量這一特性是使用,當然你還可以在其他文件上發現其他特性的使用。
4、合並編譯less文件
文件都寫好了,那怎麼把它變成bootstrap.css呢。這裡有個文件很重要,那就是bootstrap.less。最後只需要編譯該文件就可以得到css文件了。我們來看看裡面到底寫了啥:
// Core variables and mixins @import "variables.less"; // Modify this for custom colors, font-sizes, etc @import "mixins.less"; // CSS Reset @import "reset.less"; // Grid system and page structure @import "scaffolding.less"; @import "grid.less"; @import "layouts.less"; // Base CSS @import "type.less"; @import "code.less"; @import "forms.less"; @import "tables.less"; // Components: common @import "sprites.less"; @import "dropdowns.less"; @import "wells.less"; @import "component-animations.less"; @import "close.less"; // Components: Buttons & Alerts @import "buttons.less"; @import "button-groups.less"; @import "alerts.less"; // Note: alerts share common CSS with buttons and thus have styles in buttons.less // Components: Nav @import "navs.less"; @import "navbar.less"; @import "breadcrumbs.less"; @import "pagination.less"; @import "pager.less"; // Components: Popovers @import "modals.less"; @import "tooltip.less"; @import "popovers.less"; // Components: Misc @import "thumbnails.less"; @import "media.less"; @import "labels-badges.less"; @import "progress-bars.less"; @import "accordion.less"; @import "carousel.less"; @import "hero-unit.less"; // Utility classes @import "utilities.less"; // Has to be last to override when necessary
bootstrap.less作用是將其他less文件全部引入,但是引入的順序還是有要求的。比如先引入 variables.less 和 mixins.less,是因為後面的less文件用到的less特性都是來自於這兩個文件的,如果不先引入,就會出現編譯錯誤的問題。然後再引入 reset.less 重置原有的樣式。接著引入網格系統的相關文件,這是整個網格系統建立的關鍵所在。然後引入一些公用的組件,特定組件,最後就是一些無家可歸但是比較有用的樣式樣式文件:utilities.less。
最後要做的就是編譯bootstrap.less生成bootstrap.css文件。
編譯方法:
如果你用的編輯器是 sublime text 安裝less2css插件,使用需要nodejs環境,還有一個less的插件(這個你在使用的時候會提醒你缺少某個插件,然後安裝就可以了)。
用前面說的gulp工具,已經給出教程了
總結:
通過對bootstrap源碼文件的分析,既了解到了less的作用,也明白預處理器流行的原因。其中有很多思想是值得我們學習的。比如編寫一個樣式框架要考慮哪些因素,如何分工合作等等。
如果你寫的頁面,樣式比較少,不推薦使用less,有點麻煩。當然如果你配置好相關環境了(比如工作中使用gulp或webpack來實現自動化)也就不用在乎了。
如果你要寫的樣式比較多,推薦使用less。
另外bootstrap官網提供樣式定制,如果變動比較小的話,推薦直接修改bootstrap源文件,重新編譯就好。
如果大家還想深入學習,可以點擊這裡進行學習,再為大家附3個精彩的專題:
Bootstrap學習教程
Bootstrap實戰教程
Bootstrap插件使用教程
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。