scss中&代表什么

发布于 2022-09-11 22:04:12 字数 978 浏览 25 评论 0

最近在学习scss,于是看了elment-ui的源码,其中有几处不是很理解,直接上代码吧

@function selectorToString($selector) { 
  @debug '这个是' + $selector;
  $selector: inspect($selector); //cast to string
  @debug '这个是2' + inspect($selector);
  @debug '这个是2' + inspect('.block');
  $selector: str-slice($selector, 2, -2); //remove brackets 
  @debug '这个是3' + $selector;
  @return $selector; 
}

@mixin b($block) { 
  .#{$block} { 
    @content; 
  } 
}

@mixin e($element) { 
  $selector: &; 
  @debug '&是' + &;
  @if selectorToString($selector) {
    @content;
  }
}

@include b(block) { 
  background: red; 
  @include e(kindlebook) {
    background: gray;
  }
}
// $selector: selectorToString(block);
@error 1;

上面代码,打印如下:
图片描述

我想问的问题是:
为什么在函数selectorToString中,第一次打印的是.block,而第二次打印的就带上了括号呢?并且还加上了逗号,这也是我再看源码的时候对那句注释//remove brackets百思不得其解的原因。
或者更进一步的说,& 在scss中获取到底是什么样的存在。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

东北女汉子 2022-09-18 22:04:12

&代表元素自身,这里的&就是.block

.block {
  color: &;
  color: inspect(&);
}

编译结果为:

.block {
  color: .block;
  color: (.block,);
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文