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

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

作者: 哦啦吧啦丶 | 来源:发表于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

相关文章

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

    取整 直接取整 向上取整 向下取整 四舍五入 保留N位小数 四舍六入五留双 Number.toFixed()使用以...

  • 填坑之路

    总有一点东西,用一次查一次,查一次忘一次 IE 11不兼容VUE Babel 默认只转换新的 JavaScript...

  • ReactNative填坑之路

    一.ViewPagerAndroid之坑 举个栗子, 然而在HotSaleLis这个Component里面就不能超...

  • 填坑之路:JSTL

    一、什么是JSTL JSP标准标签库(JSTL)是一个JSP标签集合,它封装了JSP应用的通用核心功能,它是apa...

  • idea 填坑之路

    1、jdk与jetty有版本匹配的问题,如果版本不匹配会出现不能识别jsp的错误。 jdk1.8匹配的jett...

  • 填坑之路漫长

    最近怎么说呢,大家都感觉要凉凉了。哪里都是个坑,只不过从这个坑里跳到了另外一个坑里。 好好的填坑,才是自己该做的。...

  • Vue填坑之路

    问题1:TypeError: Cannot read property 'minify' of undefined

  • Jpush的填坑之路

    1. 通知弹不出弹出框,解决方案,想要悬浮弹出框需要在服务端设置priority 为2的优先级 2. 推送通知可以...

  • iOS填坑之2 - 如何工具化自己的开发之路,如何深入,更加深入

    iOS填坑之2 - 如何工具化自己的开发之路,如何深入,更加深入源码地址在这里跟上一篇文章文章iOS填坑之1 - ...

  • 填坑之路:iframe的各种坑

    连着两个项目遇到iframe,难受。 同域还好,不同域简直爆炸。 当然几经折磨,还是有了办法。 解决方案就是让它们...

网友评论

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

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