首页 > 代码库 > @at-root和#{&}结合
@at-root和#{&}结合
Sass有脚本模式#{}
,他和&
不同之处是,&
只用作选择器,它只能出现在一个复合的开始选择器,类似于一个类型选择器,如a
或者h1
。但#{}
他表示的是一个插值,它可以用在任何地方。同样的,当@at-root
和#{&}
一起使用时,可以给我们的开发带来极大的方便与优势。例如:
SCSS
.foo { @at-root .bar #{&} { color: gray; }}
CSS
.bar .foo { color: gray; }
可能会让你感到意外与失望,因为你从上面的代码之中并没有看到他有特别之处。或者说能帮你减少什么?也不能帮你优化什么?不过不用太心急,接着往下看。
先快速回忆一下BEM,如:
.block {} //Block.block__element{} //Element.block--modifier{} //Modifier
此时使用@at-root
就能尽显其英雄本色:
SCSS
.block { color:red; @at-root #{&}__element{ color:green; } @at-root #{&}--modifier { color:blue; }}
CSS
.block { color: red; }.block__element { color: green; }.block--modifier { color: blue; }
到了这里,你是否体会到@at-root
在BEM中是具有多大的优势了吧。不急,后面将来个实例,让你一览其整个过程。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。