他们是在 sass 中更改舍入发生的数字的一种方式,我想停止将 2.0242914979757085% 这样的数字舍入到 2.024%。我想调整输出 css 中的小数位数
问问题
18583 次
5 回答
26
没有任何额外功能的快速选择是将数字乘以 1000,然后将其四舍五入,然后除以 1000。
round($percent * 1000) / 1000;
于 2016-07-19T04:20:40.897 回答
11
从 SASS 更改日志中:
现在可以使用--precision
命令行选项设置 Sass 中数字的数值精度。此外,现在可以通过将 Sass::Script::Number.precision 设置为整数(默认为 3)来更改 Sass 输出中的默认精度位数。由于现在可以更改此值,因此不推荐使用 Sass::Script::Number 中的 PRECISION 常量。万一您在代码中使用它,您现在应该改用 Sass::Script::Number.precision_factor。
这是在 SASS 3.1.8 中添加的。
于 2012-04-29T04:52:05.800 回答
7
您可以使用以下函数,这是对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-01-24T23:02:51.387 回答
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 );
}
于 2014-04-14T16:15:49.577 回答
0
严格来说,这不是您问题的答案,但如果您只想去除小数位,您不妨这样做:
font-size: round(12.5); /* => 12 */
它可能适用于不需要高精度的值,例如字体大小。
于 2020-02-28T17:56:56.747 回答