美文网首页
填坑之路:常见的数字操作

填坑之路:常见的数字操作

作者: 哦啦吧啦丶 | 来源:发表于2019-07-16 18:45 被阅读0次

    取整

    直接取整
    parseInt(5/3) // 1
    
    向上取整
    Math.ceil(5/3) // 2
    
    向下取整
    Math.floor(5/3) // 1
    
    四舍五入
    Math.round(5/3) // 2
    

    保留N位小数

    四舍六入五留双

    Number.toFixed()使用以上规则,即银行家舍入规则,数字经转换后变为字符串,不足位将补0,返回string类型值

    (1.15).toFixed(2) // 1.15
    (1.15).toFixed(3) // 1.150
    (1.15).toFixed(1) // 1.1
    (1.25).toFixed(1) // 1.3
    
    四舍五入

    位数大于n时将四舍五入,不足位不补0

    var round = (num, n) => {
      return Math.round(num * Math.pow(10, n)) / Math.pow(10, n)
    }
    
    直接截断
    • 位数大于n时将直接截断多余部分,不足位不补0
    var parse = (num, n) => {
      return parseInt(num * Math.pow(10, n)) / Math.pow(10, n)
    }
    
    • 截断含多位小数的number,保留指定位小数
    let num = 5/3 + ''
    // 1
    num.match(/\d+(?:\.)\d{2}/)[0] // 1.66
    // 2
    num.substring(0, num.indexOf(".") + 3) // 1.66
    
    不足位补0

    如以上两种,如果需求要补0,则

    var parse = (num, n, { needZero = false } = {}) => {
        var result = parseInt(num * Math.pow(10, n)) / Math.pow(10, n)
        if (needZero && n > 0) {
            var _result = result + ''
            var dotIndex = _result.indexOf('.')
            if (dotIndex < 0) {
                dotIndex = _result.length;
                _result += '.'
            }
            while (_result.length <= dotIndex + n) {
                _result += '0'
            }
            return _result
        }
        return result
    }
    parse(221.2, 5, { needZero: true })
    
    还有吗?
    toPrecision

    Number.toPrecision([precision])函数返回一个字符串,该字符串以指数记数法定点记数法来表示当前数值。

    我们先看看规则:

    • 如果该数字的有效位数小于precision位,则在小数部分不足位补0

    • 如果该数字整数部分的位数小于等于参数precision,则返回值将采用定点表示法;否则将采用指数计数法。

    那么如果想要使用其保留小数的特性,就该满足:参数percision大于数字有效位(补0机制),或者至少大于等于其整数部分位数(奇怪的四舍五入)

    (1.545).toPrecision(1) // 2
    (1.545).toPrecision(2) // 1.5
    (1.545).toPrecision(3) // 1.54
    (1.545).toPrecision(4) // 1.545
    (1.545).toPrecision(5) // 1.5450
    
    toLocaleString

    numObj.toLocaleString([locales [, options]]) 返回这个数字在特定语言环境下的表示字符串,详转MDN

    关于toLocaleString还有很多奇招,这里挑点符合主题的讲(配置useGroupingfalse将去掉默认的分组分隔符)。

    • minimumIntegerDigits: 使用的整数数字的最小数目
    • minimumFractionDigits: 使用的小数位数的最小数目
    • maximumFractionDigits: 使用的小数位数的最大数目
    • minimumSignificantDigits: 使用的有效数字的最小数目
    • maximumSignificantDigits: 使用的有效数字的最大数量

    它们都将四舍五入:

    (1.545).toLocaleString('zh', { minimumIntegerDigits: 2, useGrouping: false }) // 01.545
    (1.545).toLocaleString('zh', { minimumFractionDigits: 4, useGrouping: false }) // 1.5450
    (1.545).toLocaleString('zh', { maximumFractionDigits: 2, useGrouping: false }) // 1.55
    (1.545).toLocaleString('zh', { minimumSignificantDigits: 5, useGrouping: false }) // 1.5450
    (1.545).toLocaleString('zh', { maximumSignificantDigits: 3, useGrouping: false }) // 1.55
    

    相关文章

      网友评论

          本文标题:填坑之路:常见的数字操作

          本文链接:https://www.haomeiwen.com/subject/ltfxlctx.html