2

是否有解决方法或任何其他方法可以在 Sass 3.4 + 上进行这项工作

@mixin icon ($name, $code) {
.#{$name}::before {
content: str-slice("\x",1,1) + $code;}
}

@include icon('test', 4556);

代码应该输出

.test::before { 内容:“\4556”;}

但是在 3.4+ 上,\斜线被删除并输出为

.test::before { 内容:“x4556”;}

谢谢

4

2 回答 2

10

您偶然发现了Sass 中转义字符的当前争论的问题。目前,Sass 似乎要么添加太多字符,要么最终将 unicode 字符放入输出 css。

更新:

@mixin icon ($name, $code) {
  $withslash: "\"\\#{$code}\"";
  .#{$name}:before {
    content: unquote($withslash);
  }
}
@include icon('test', '4556');

输出

.test:before {
  content: "\4556";
}

http://sassmeister.com/gist/04f5be11c5a6b26b8ff9

显然,这种方法的缺点是它依赖于使用转义字符做奇怪的事情并欺骗 Sass 取消引用可能格式错误的字符串。

于 2014-09-30T03:24:07.767 回答
0

或者,您可以使用辅助函数从字符串中删除空格:

@function nospaces($str) {
  @while (str-index($str, ' ') != null) {
    $index: str-index($str, ' ');
    $str: "#{str-slice($str, 0, $index - 1)}#{str-slice($str, $index + 1)}";
  }
  @return $str;
}

然后函数看起来像这样:

@mixin icon ($name, $code) {
  .#{$name}:before {
    content: nospaces("\ #{$code}");
  }
}

@include icon('test', '4556');

或不带引号:

@mixin icon ($name, $code) {
  .#{$name}:before {
    content: nospaces(\ #{$code});
  }
}

@include icon('test', '4556');
于 2018-05-02T11:41:35.283 回答