亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

關于@at-root

何種情況下使用呢?請教

正在回答

3 回答

我的理解就是為了減少權重,既然這樣干嘛還要寫嵌套呢?

0 回復 有任何疑惑可以回復我~

sass語法:

.block {

? ? color: red;

? ? #{&}__element {

? ? ? ? color:blue;

? ? }

? ? #{&}--modifier {

? ? ? ? color: orange;

? ? }

}

css結果:

.block {

? color: red;

}

.block .block__element {

? color: blue;

}

.block .block--modifier {

? color: orange;

}


這里我們實現的是BEM約定的css命名規則,不希望嵌套的發生,則可以使用@at-root,它在sass>3.3版本以上才有這個功能,改寫如下:

sass語法:

.block {

? ? color: red;

? ? @at-root #{&}__element {

? ? ? ? color: blue;

? ? }

? ? @at-root #{&}--modifier {

? ? ? ? color:orange;

? ? }

}

css結果:

.block {

? color: red;

}

.block__element {

? color: blue;

}

.block--modifier {

? color: orange;

}


詳細了解看如下網址:

sass @at-root?

http://www.w3cplus.com/preprocessor/Sass-3-3-new-feature-at-root-bem.html

BEM css命名規則:

https://en.bem.info/method/naming-convention/


2 回復 有任何疑惑可以回復我~
#1

慕粉1137201464

我的理解就是為了減少權重,既然這樣干嘛還要寫嵌套呢?
2017-03-29 回復 有任何疑惑可以回復我~

這是sass3.3的內容

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
Sass進階篇
  • 參與學習       46637    人
  • 解答問題       98    個

對Sass其它較有難度的部分進行講解,包括常用控制命令、函數

進入課程

關于@at-root

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號