Sass 3.4删除字符串上的正斜杠

use*_*442 2 sass compass

是一个解决方法或任何其他方式使这个工作在Sass 3.4 +

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

@include icon('test', 4556);
Run Code Online (Sandbox Code Playgroud)

代码应该输出

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

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

.test :: before {content:"x4556"; }

谢谢

din*_*arl 9

你偶然发现了目前在Sass中使用转义字符的辩论问题.看来,目前,Sass要么添加太多字符,要么最终将unicode字符放入输出css中.

更新:

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

输出

.test:before {
  content: "\4556";
}
Run Code Online (Sandbox Code Playgroud)

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

显然,这种方法的缺点在于它依赖于使用转义字符进行奇怪的操作并欺骗Sass以取消对可能格式错误的字符串的引用.