8

我有什么办法可以修改 Sass 处理小数位的方式吗?看到有几个人说sass会动态做响应式布局需要的(target/parent)*100计算,并在编译时输出结果。它甚至还有一个百分比函数,它本质上将采用两个值并执行此操作。

唉,Sass 只会给我 3 位小数。到目前为止,我的理解是,在某些情况下,这可能不足以让所有浏览器正确显示布局而不会出现任何问题。

任何人都可以帮助我了解这一点吗?

编辑

解决了。万一其他人感兴趣,我设法在 Sass 的 number.rb 中完成了我想要的,改变了@precision 的值。这改变了所有浮点数的输出方式。

4

3 回答 3

14

如果您使用的是 Compass,您可以轻松地在项目文件 (config.rb) 中指定精度,而无需破解核心:

Sass::Script::Number.precision = 8

有关更多信息,请参阅Sass 文档

于 2012-07-31T17:31:55.320 回答
5

它也可以--precision在命令行中配置,参见SASS Changelog, version 3.1.8

还应该补充一点,如果你想直接编辑@precisionnumbers.rb你可以在这里找到numbers.rb(至少在 OS X 上):

/usr/lib/ruby/user-gems/1.8/gems/sass-3.1.10/lib/sass/script

1.8 和 3.1.10 当然应该替换为您的(最好是最新的)版本号。

于 2011-11-07T15:27:39.343 回答
1

首先将默认精度设置为项目所需的最高精度。

然后,使用如下函数(基于Takeru Suzuki 的此函数)在单个属性级别自定义小数位数。

代码 :

@function decimal-round ($number, $digits: 0, $mode: round) {
    $n: 1;
    // $number must be a number
    @if type-of($number) != number {
        @warn '#{ $number } is not a number.';
        @return $number;
    }
    // $digits must be a unitless number
    @if type-of($digits) != number {
        @warn '#{ $digits } is not a number.';
        @return $number;
    } @else if not unitless($digits) {
        @warn '#{ $digits } has a unit.';
        @return $number;
    }
    @if $digits > 0 {
        @for $i from 1 through $digits {
            $n: $n * 10;
        }
    }
    @if $mode == round {
        @return round($number * $n) / $n;
    } @else if $mode == ceil {
        @return ceil($number * $n) / $n;
    } @else if $mode == floor {
        @return floor($number * $n) / $n;
    } @else {
        @warn '#{ $mode } is undefined keyword.';
        @return $number;
    }
}

输出 :

decimal-round(0.333)    => 0
decimal-round(0.333, 1) => 0.3
decimal-round(0.333, 2) => 0.33
decimal-round(0.666)    => 1
decimal-round(0.666, 1) => 0.7
decimal-round(0.666, 2) => 0.67
于 2016-10-07T15:24:40.910 回答