Sass 中的四舍五入数字和调整小数位数

问题描述 投票:0回答:7

他们是在 sass 中更改发生四舍五入的数字的一种方法,我想停止将这样的数字四舍五入 2.0242914979757085% 到 2.024%。我想调整输出 css 中的小数位数

css math sass numbers rounding
7个回答
31
投票

没有任何额外功能的快速选项是将数字乘以 1000,然后四舍五入,然后除以 1000。

round($percent * 1000) / 1000;

12
投票

来自 SASS 更改日志:

现在可以使用命令行的

--precision
选项设置Sass中数字的数字精度。此外,现在可以通过将 Sass::Script::Number.precision 设置为整数(默认为 3)来更改 Sass 输出中的默认精度位数。由于现在可以更改此值,因此 Sass::Script::Number 中的 PRECISION 常量已被弃用。万一您在代码中使用它,您现在应该改用 Sass::Script::Number.precision_factor。

这是在 SASS 3.1.8 中添加的


9
投票

您可以使用以下函数,这是对 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

2
投票

您还可以执行以下操作:

@function ceilHundredths($numbers) {
    $numbers: $numbers * 10000;

    @if ($numbers < 1) {
        $numbers: $numbers - 1;

    } @else {
        $numbers: $numbers + 1;
    }

    @return round($numbers)/ 100#{"%"};

}

.test--regular {
    margin-left: percentage( -1 / 3 );
}

.test {
    margin-left: ceilHundredths( -1 / 3 );
}

.test--regular--2 {
    margin-left: percentage( 1 / 3 );
}

.test--2 {
    margin-left: ceilHundredths( 1 / 3 );
}

0
投票

严格来说,这不是你问题的答案,但如果你只想 strip 小数位,你不妨这样做:

font-size: round(12.5); /* => 12 */

它可能适用于 not 需要高精度的值,例如字体大小。


0
投票

这是我的 sass 舍入函数

@function round($value, $fractionDigits: 0) {
  $power: math.pow(10, $fractionDigits);
  @return math.div(math.round($power * $value), $power);
}

用法:

round(2.0242914979757085%, 3) // 2.024%

别忘了添加

sass:math
模块,像这样:

@use "sass:math";

附言这是我使用的以下 JS 方法的 sass 端口:

export const round = (value, fractionDigits = 0) => {
  const power = Math.pow(10, fractionDigits);
  return Math.round(power * value) / power;
};

0
投票

我们只需使用

floor(n*1000)/1000

您可以创建自己的自定义函数来执行此操作

@function  fn-truncate($value, $places) {
  $radix: 10;
  $num: 1;
  $result : 0;

  @for $i from 1 through $places {
    $num: $num * $radix;
  }

  $result: math.div(math.floor($value * $num), $num);

  @return $result;
}

输入:

  @debug "fn-truncate(123.4999, 2) : #{fn-truncate(123.4999, 2)}";
  @debug "fn-truncate(123.4999, 1) : #{fn-truncate(123.4999, 1)}";
  @debug "fn-truncate(123.999, 2) : #{fn-truncate(123.999, 2)}";
  @debug "fn-truncate(123.6999, 1) : #{fn-truncate(123.6999, 1)}";
  @debug "fn-truncate(123.2, 3) : #{fn-truncate(123.2, 3)}";
  @debug "fn-truncate(123.123456, 2) : #{fn-truncate(123.123456, 2)}";
  @debug "fn-truncate(123, 2) : #{fn-truncate(123, 2)}";
  @debug "fn-truncate(123.45, 3) : #{fn-truncate(123.45, 3)}";

输出

src/styles/_functions.scss:65 DEBUG: fn-truncate(123.4999, 2) : 123.49
src/styles/_functions.scss:66 DEBUG: fn-truncate(123.4999, 1) : 123.4
src/styles/_functions.scss:67 DEBUG: fn-truncate(123.999, 2) : 123.99
src/styles/_functions.scss:68 DEBUG: fn-truncate(123.6999, 1) : 123.6
src/styles/_functions.scss:69 DEBUG: fn-truncate(123.2, 3) : 123.2
src/styles/_functions.scss:70 DEBUG: fn-truncate(123.123456, 2) : 123.12
src/styles/_functions.scss:71 DEBUG: fn-truncate(123, 2) : 123
src/styles/_functions.scss:72 DEBUG: fn-truncate(123.45, 3) : 123.45

此外,您可以根据您的要求在 fn-truncate() 中添加更多检查/处理输入单元等,例如

$places
不应为 0 或您希望如何处理该用例,
$value
 $places
应该是一个数字,使用
type-of($value) == 'number'
以及您能想到的更多用例。

谢谢

最新问题
© www.soinside.com 2019 - 2024. All rights reserved.