zoukankan      html  css  js  c++  java
  • JavaScript 保留两位小数函数

    四舍五入

    以下处理结果会四舍五入:

    var num =2.446242342;
    num = num.toFixed(2);  // 输出结果为 2.45

    不四舍五入

    以下处理结果不会四舍五入。

    第一种,先把小数变整数:

    Math.floor(15.7784514000 * 100) / 100   // 输出结果为 15.77

    第二种,当作字符串,使用正则匹配:

    Number(15.7784514000.toString().match(/^d+(?:.d{0,2})?/))   // 输出结果为 15.77,不能用于整数如 10 必须写为10.0000

    注意:如果是负数,请先转换为正数再计算,最后转回负数

    注意:Math.floor()容易出现精度问题,举个最简单例子:
    
    对小数 8.54 保留两位小数(虽然它已经保留了 2 位小数):
    
    Math.floor(8.54*100)/100 // 输出结果为 8.53, 注意是 8.53 而不是 8.54。
    
    所以这种函数慎用。
    
    更多内容参考:JavaScript 中精度问题以及解决方案
    
    xuxs
       xuxs
    
      xux***shunshun@163.com
    
    2年前 (2018-06-22)
       dbstt
    
      dbs***qq.com
    
    17
    也可以先转换为字符串,再进行截取,再转回数字,就触决了精度的问题。
    
    let num = 12.333333333333333
    let numStr = num.toString()
    let index = numStr.indexOf('.')
    let result = numStr.slice(0, index + 3)
    结果就是 12.33 类型为 string。
    
    需要数值类型的话:
    
    Number(result)
    也可以直接写成:
    
    let result = Number( numStr.slice(0, index + 3) )  
  • 相关阅读:
    vue学习笔记 样式 class style(五)
    vue学习笔记 计算属性(四)
    vue学习笔记 模板语法(三)
    vue学习笔记 实例(二)
    vue学习笔记 概述(一)
    Babel指南——基本环境搭建
    手动es6编译es5(命令行)
    TrimPath
    git 远程仓库管理
    CSS左侧固定宽 右侧自适应(兼容所有浏览器)
  • 原文地址:https://www.cnblogs.com/zhangyezi/p/13277702.html
Copyright © 2011-2022 走看看