Фиксирайте число в N цифри - CSS-трикове

Anonim

Когато се занимавате с числа в JavaScript или който и да е друг език за програмиране, има начин да съкратите число след nцифри. За съжаление в Sass няма такава функция. И все пак проблемите със закръгляването и точността се случват, когато се занимават например с базирани на проценти мрежови системи.

Ето внедряване на Sass на toFixed():

/// toFixed() function in Sass /// @author Hugo Giraudel /// @param (Number) $float - Number to format /// @param (Number) $digits (2) - Number of digits to leave /// @return (Number) @function to-fixed($float, $digits: 2) ( $sass-precision: 5; @if $digits > $sass-precision ( @warn "Sass sets default precision to #($sass-precision) digits, and there is no way to change that for now." + "The returned number will have #($sass-precision) digits, even if you asked for `#($digits)`." + "See https://github.com/sass/sass/issues/1122 for further informations."; ) $pow: pow(10, $digits); @return round($float * $pow) / $pow; )

Имайте предвид, че Sass има точност по подразбиране от 5 цифри и от днес няма начин да я конфигурирате. Поради това не е възможно Sass да изчисли число с повече от 5 цифри, независимо от броя, даден на функцията като $digits.

Също така, тази функция изисква powфункция, която не се присъединява към Sass (все още). Той съществува в Compass, но ако не използвате Compass или друга библиотека, която го предоставя, може да се нуждаете от собствена powфункция. За щастие е доста лесно да се приложи:

/// Power function /// @param (Number) $x /// @param (Number) $n /// @return (Number) @function pow($x, $n) ( $ret: 1; @if $n >= 0 ( @for $i from 1 through $n ( $ret: $ret * $x; ) ) @else ( @for $i from $n to 0 ( $ret: $ret / $x; ) ) @return $ret; )