@at-root和#{&}结合

本文深入探讨了Sass中的@at-root特性与BEM(Block, Element, Modifier)方法的结合应用,展示了如何利用@at-root简化BEM样式规则的编写,提高开发效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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中是具有多大的优势了吧。不急,后面将来个实例,让你一览其整个过程。

 

转载于:https://www.cnblogs.com/aobingyan/p/3809093.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值