Rounding numbers in Sass and adjusting the amount of decimals

后端 未结 5 1873
失恋的感觉
失恋的感觉 2020-12-10 15:06

Is their a way in sass to change the digit that rounding occurs on, I would like to stop rounding of a number like this 2.0242914979757085% to this 2.024%. I would like to a

相关标签:
5条回答
  • 2020-12-10 15:25

    You could use the following function, which is a slight improvement of the function created by 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;
        }
    }
    

    Output :

    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
    
    0 讨论(0)
  • 2020-12-10 15:26

    Strictly speaking this is not an answer to your question but if you just want to strip decimal places, you might as well just do this:

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

    It may be appropriate with values that do not require a high level of precision, as for example with font sizes.

    0 讨论(0)
  • 2020-12-10 15:30

    From the SASS change logs:

    The numeric precision of numbers in Sass can now be set using the --precision option to the command line. Additionally, the default number of digits of precision in Sass output can now be changed by setting Sass::Script::Number.precision to an integer (defaults to 3). Since this value can now be changed, the PRECISION constant in Sass::Script::Number has been deprecated. In the unlikely event that you were using it in your code, you should now use Sass::Script::Number.precision_factor instead.

    This was added in SASS 3.1.8.

    0 讨论(0)
  • 2020-12-10 15:37

    You could also do the following:

    @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 讨论(0)
  • 2020-12-10 15:40

    A quick option without any extra functions would be to multiply the number by 1000, then round it, then divide by 1000.

    round($percent * 1000) / 1000;
    
    0 讨论(0)
提交回复
热议问题