這篇文章主要介紹CSS動(dòng)態(tài)樣式語(yǔ)言less語(yǔ)法混合屬性怎么用,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
創(chuàng)新互聯(lián)建站是一家專業(yè)提供桓仁企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計(jì)制作、做網(wǎng)站、HTML5建站、小程序制作等業(yè)務(wù)。10年已為桓仁眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。
混合:
在 LESS 中我們可以定義一些通用的屬性集為一個(gè)選擇器,然后在另一個(gè)選擇器中去調(diào)用這些屬性. 例如:
復(fù)制代碼
代碼如下:
.a, #b {
color: red;
}
.mixin-class {
.a();
}
.mixin-id {
#b();
}
編譯后
復(fù)制代碼
代碼如下:
.a, #b {
color: red;
}
.mixin-class {
color: red;
}
.mixin-id {
color: red;
}
注意:在調(diào)用混合時(shí),可以加括號(hào)也可以不加括號(hào)。下面這個(gè)也是對(duì)的:
復(fù)制代碼
代碼如下:
.a, #b {
color: red;
}
.mixin-class {
.a;
}
.mixin-id {
#b;
}
如果你只想定義一個(gè)混合,則可以再選擇器后面加上括號(hào),如下:
復(fù)制代碼
代碼如下:
.my-mixin {
color: black;
}
.my-other-mixin() {
background: white;
}
.class {
.my-mixin;
.my-other-mixin;
}
編譯后,加括號(hào)的.my-other-mixin()不會(huì)被編譯。
復(fù)制代碼
代碼如下:
.my-mixin {
color: black;
}
.class {
color: black;
background: white;
}
任何 CSS class, id 或者 元素 屬性集都可以以同樣的方式引入.通用選擇器中可以嵌套選擇器。
命名空間:
如果你想混合屬性在一個(gè)更復(fù)雜的選擇器,可以疊放多個(gè)id或類。如下:
復(fù)制代碼
代碼如下:
#outer {
.inner {
color: red;
}
}
如果想使用這個(gè)混合屬性,你可以這樣,下面四個(gè)都是等價(jià)的
復(fù)制代碼
代碼如下:
.c{
#outer > .inner;
}
.c{
#outer > .inner();
}
.c{
#outer.inner;
}
.c{
#outer.inner();
}
你可以將混合屬性定義在一個(gè)id的下面,這樣就避免了與其他混合沖突。
關(guān)鍵字!important:
在使用混合屬性后面加上!important關(guān)鍵字,則混合中的所有屬性都會(huì)加上關(guān)鍵字!important。例如:
復(fù)制代碼
代碼如下:
.foo (@bg: #f5f5f5, @color: #900) {
background: @bg;
color: @color;
}
.unimportant {
.foo(1);
}
.important {
.foo(2) !important;
}
編譯后
復(fù)制代碼
代碼如下:
.unimportant {
background: #f5f5f5;
color: #900;
}
.important {
background: #f5f5f5 !important;
color: #900 !important;
}
帶參數(shù)的混合:
混合屬性也可以通過(guò)括號(hào)傳遞參數(shù),如下:
復(fù)制代碼
代碼如下:
.border-radius(@radius) {
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
border-radius: @radius;
}
我們只需要在使用它的時(shí)候傳遞一個(gè)參數(shù)即可,如下:
復(fù)制代碼
代碼如下:
#header {
.border-radius(4px);
}
.button {
.border-radius(6px);
}
當(dāng)然我們也可以給參數(shù)一個(gè)默認(rèn)值,這樣使用的時(shí)候可以傳值也可以不傳值。如下:
復(fù)制代碼
代碼如下:
.border-radius(@radius: 5px) {
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
border-radius: @radius;
}
如果我們沒(méi)有傳值,則會(huì)使用默認(rèn)值5px。
當(dāng)然我們也可以傳遞多個(gè)參數(shù),如下:
復(fù)制代碼
代碼如下:
.mixin(@color) {
color-1: @color;
}
.mixin(@color; @padding:2) {
color-2: @color;
padding-2: @padding;
}
.mixin(@color; @padding; @margin: 2) {
color-3: @color;
padding-3: @padding;
margin: @margin @margin @margin @margin;
}
.some .selector div {
.mixin(#008000);
}
編譯后
復(fù)制代碼
代碼如下:
.some .selector div {
color-1: #008000;
color-2: #008000;
padding-2: 2;
}
從編譯的結(jié)果可以看出,less也有函數(shù)重載的特性。當(dāng)我們定義相同混合屬性名,參數(shù)不同,然后.mixin(#008000);調(diào)用,第一和第二混合都能匹配,但是第三個(gè)缺少參數(shù)@padding的值,所以不會(huì)引用第三個(gè)混合屬性。
我們不僅可以傳多個(gè)值,還可以指定屬性名傳值,如下:
復(fù)制代碼
代碼如下:
.mixin(@color: black; @margin: 10px; @padding: 20px) {
color: @color;
margin: @margin;
padding: @padding;
}
.class1 {
.mixin(@margin: 20px; @color: #33acfe);
}
.class2 {
.mixin(#efca44; @padding: 40px);
}
關(guān)鍵字@arguments:
@arguments有特殊的含義,類似于js的arguments,他包含了傳遞給混合屬性的所有參數(shù),如下:
復(fù)制代碼
代碼如下:
.box-shadow(@x: 0; @y: 0; @blur: 1px; @color: #000) {
-webkit-box-shadow: @arguments;
-moz-box-shadow: @arguments;
box-shadow: @arguments;
}
.big-block {
.box-shadow(2px; 5px);
}
編譯后
復(fù)制代碼
代碼如下:
.big-block {
-webkit-box-shadow: 2px 5px 1px #000;
-moz-box-shadow: 2px 5px 1px #000;
box-shadow: 2px 5px 1px #000;
}
關(guān)鍵字@reset:
與@arguments不同的是@reset包含除指明參數(shù)之外的參數(shù),例如:
復(fù)制代碼
代碼如下:
.mixin(@a; @rest...) {
// @rest包含了@a之后的參數(shù)
// @arguments包含了所有參數(shù)
}
模式匹配:
有時(shí)候你想讓混合根據(jù)你傳入的參數(shù)做不同的事情,比如:
復(fù)制代碼
代碼如下:
.mixin(dark; @color) {
color: darken(@color, 10%);
}
.mixin(light; @color) {
color: lighten(@color, 10%);
}
.mixin(@_; @color) {
display: block;
}
.class {
.mixin(@switch; #888);
}
對(duì)于.class你賦給變量@switch不同的值,不同的混合屬性會(huì)被調(diào)用,比如
@switch: light;
編譯后
復(fù)制代碼
代碼如下:
.class {
color: #a2a2a2;
display: block;
}
作為函數(shù)使用Mixin:
當(dāng)我們把混合當(dāng)做函數(shù)使用時(shí),在調(diào)用函數(shù)之后,函數(shù)中的變量是可以使用的,除非調(diào)用混合屬性的元素自己定義了同樣的變量。比如:
復(fù)制代碼
代碼如下:
.mixin() {
@width: 100%;
@height: 200px;
}
.caller {
.mixin();
width: @width;
height: @height;
}
編譯后
復(fù)制代碼
代碼如下:
.caller {
width: 100%;
height: 200px;
}
使用表達(dá)式:
復(fù)制代碼
代碼如下:
.average(@x, @y) {
@average: ((@x + @y) / 2);
}
div {
.average(16px, 50px); // "call" the mixin
padding: @average; // use its "return" value
}
編譯后
復(fù)制代碼
代碼如下:
div {
padding: 33px;
}
LESS VS SASS
同類框架還有 SASS : http://sass-lang.com/, 與 LESS 相比,兩者都屬于 CSS 預(yù)處理器,功能上大同小異,都是使用類似程序式語(yǔ)言的方式書寫 CSS, 都具有變量、混入、嵌套、繼承等特性,最終目的都是方便 CSS 的書寫及維護(hù)。
以上是“CSS動(dòng)態(tài)樣式語(yǔ)言less語(yǔ)法混合屬性怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!