你可能不知道的 JavaScript 中数字取整
网上方法很多,标题党一下,勿拍 ^_^!实际开发过程中经常遇到数字取整问题,所以这篇文章收集了一些方法,以备查询。
常用的直接取整方法
直接取整就是舍去小数部分。
1、parseInt()
parseInt() 函数解析一个字符串参数,并返回一个指定基数的整数 (数学系统的基础)。这个估计是直接取整最常用的方法了。
示例:
- parseInt("2015nov"), //2015
- parseInt(""), //NaN
- parseInt("0xA"), //10(十六进制)
- parseInt(20.15), //20
- parseInt(-20.15), //-20
- parseInt("070"); //56(八进制数)
更多关于 parseInt() 函数可以查看 MDN 文档
2、Math.trunc()
Math.trunc() 方法会将数字的小数部分去掉,只保留整数部分。
- Math.trunc(13.37) // 13
- Math.trunc(42.84) // 42
- Math.trunc(0.123) // 0
- Math.trunc(-0.123) // -0
- Math.trunc("-1.123") // -1
- Math.trunc(NaN) // NaN
- Math.trunc("foo") // NaN
- Math.trunc() // NaN
特别要注意的是:Internet Explorer 不支持这个方法,不过写个Polyfill也很简单:
- Math.trunc = Math.trunc || function(x) {
- if (isNaN(x)) {
- return NaN;
- }
- if (x > 0) {
- return Math.floor(x);
- }
- return Math.ceil(x);
- };
数学的事情还是用数学方法来处理比较好。
快速的取整方法
除了上面这2个办法,我们可以使用按位运算符来实现数字取整。 所有的按位运算都以带符号的32位整数进行。 使用它们将可以将 float 转换为整数。 但是也存在一些问题,我们可以安全取整的数字范围为 ±2^31−1 即:2147483647,远远小于 Number.MAX_VALUE(1.7976931348623157e + 308)。 下面是一些例子:
1、~~number
双波浪线 ~~ 操作符也被称为“双按位非”操作符。你通常可以使用它作为代替 Math.trunc() 的更快的方法。
- console.log(~~47.11) // -> 47
- console.log(~~1.9999) // -> 1
- console.log(~~3) // -> 3
- console.log(~~[]) // -> 0
- console.log(~~NaN) // -> 0
- console.log(~~null) // -> 0
失败时返回0,这可能在解决 Math.trunc() 转换错误返回 NaN 时是一个很好的替代。
但是当数字范围超出 ±2^31−1 即:2147483647 时,异常就出现了:
- // 异常情况
- console.log(~~2147493647.123) // -> -21
2、number|0
| (按位或) 对每一对比特位执行或(OR)操作。
- console.log(20.15|0); // -> 20
- console.log((-20.15)|0); // -> -20
- console.log(3000000000.15|0); //
3、number^0
^ (按位异或),对每一对比特位执行异或(XOR)操作。
- console.log(20.15^0); // -> 20
- console.log((-20.15)^0); // -> -20
- console.log(3000000000.15^0); // -> -1294967296
4、number<<0
<< (左移) 操作符会将第一个操作数向左移动指定的位数。向左被移出的位被丢弃,右侧用 0 补充。
- console.log(20.15 < < 0); // -> 20
- console.log((-20.15) < < 0); //-20
- console.log(3000000000.15 << 0); // -> -1294967296
上面这些按位运算符方法执行很快,当你执行数百万这样的操作非常适用,速度明显优于其他方法。但是代码的可读性比较差。还有一个特别要注意的地方,处理比较大的数字时(当数字范围超出 ±2^31−1 即:2147483647),会有一些异常情况。使用的时候明确的检查输入数值的范围。
舍入舍去取整
舍入舍去取整也非常常见,JavaScript 的 Math 对象中有明确的方法支持:
1、四舍五入 Math.round(number)
Math.round() 是 Math 对象中的一个方法,将数值四舍五入为最接近的整数。
- console.log(Math.round(20.1)); // -> 20
- console.log(Math.round(20.5)); // -> 21
- console.log(Math.round(20.9)); // -> 21
- console.log(Math.round(-20.1)); // -> -20
- console.log(Math.round(-20.5)); // -> -20 注意这里是-20而不是-21
- console.log(Math.round(-20.9)); // -> -21
2、向下取整 Math.floor(number)
Math.floor()这个方法取向下最接近的整数。
- console.log(Math.floor(20.1)); // -> 20
- console.log(Math.floor(20.5)); // -> 20
- console.log(Math.floor(20.9)); // -> 20
- console.log(Math.floor(-20.1)); // -> -21
- console.log(Math.floor(-20.5)); // -> -21
- console.log(Math.floor(-20.9)); // -> -21
3、向上取整 Math.ceil(number)
Math.ceil()这个方法取向上最接近的整数。
- console.log(Math.ceil(20.1)); // -> 21
- console.log(Math.ceil(20.5)); // -> 21
- console.log(Math.ceil(20.9)); // -> 21
- console.log(Math.ceil(-20.1)); // -> -20
- console.log(Math.ceil(-20.5)); // -> -20
- console.log(Math.ceil(-20.9)); // -> -20
Fundebug提供JavaScript监控,支持所有主流前端框架,微信小程序监控,微信小游戏监控,后端Node.js监控。

您可能感兴趣的
原文链接:http://www.css88.com/archives/8488
你可能不知道的 JavaScript 中数字取整的更多相关文章
- javaScript中小数取整,四种方法的比较
1.parseInt:只取整数位例如:parseInt(3.7) 取整结果为:3parseInt(-1.1) 取整结果为:-1 2.Math.floor :向下去整,取大的整数例如:Math.floo ...
- 闭包----你所不知道的JavaScript系列(4)
一.闭包是什么? · 闭包就是可以使得函数外部的对象能够获取函数内部的信息. · 闭包是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分. · 闭包就 ...
- js值----你所不知道的JavaScript系列(6)
1.数组 在 JavaScript 中,数组可以容纳任何类型的值,可以是字符串.数字.对象(object),甚至是其他数组(多维数组就是通过这种方式来实现的) .----<你所不知道的JavaS ...
- js类型----你所不知道的JavaScript系列(5)
ECMAScirpt 变量有两种不同的数据类型:基本类型,引用类型.也有其他的叫法,比如原始类型和对象类型等. 1.内置类型 JavaScript 有七种内置类型: • 空值(null) • 未定义( ...
- let和const----你所不知道的JavaScript系列(2)
let 众所周知,在ES6之前,声明变量的关键字就只有var.var 声明变量要么是全局的,要么是函数级的,而无法是块级的. var a=1; console.log(a); console.log( ...
- LHS 和 RHS----你所不知道的JavaScript系列(1)
变量的赋值操作会执行两个动作, 首先编译器会在当前作用域中声明一个变量(如果之前没有声明过), 然后在运行时引擎会在作用域中查找该变量, 如果能够找到就会对它赋值.----<你所不知道的Ja ...
- Lodash 严重安全漏洞背后 你不得不知道的 JavaScript 知识
摘要: 详解原型污染. 原文:Lodash 严重安全漏洞背后 你不得不知道的 JavaScript 知识 作者:Lucas HC Fundebug经授权转载,版权归原作者所有. 可能有信息敏感的同学已 ...
- JavaScript 系列--JavaScript一些奇淫技巧的实现方法(三)数字取整,数组求和
一.前言 简短的sleep函数,获取时间戳:https://www.mwcxs.top/page/746.html 数字格式化 1234567890 --> 1,234,567,890:argr ...
- javascript 解决默认取整的坑(目前已知的最佳解决方案)
javascript 解决默认取整的坑(目前已知的最佳解决方案) 复现该问题 js在数字操作时总会取更高精度的结果,例如1234/10结果就是123.4,但是在c或者java中整数除以10的结果还是整 ...
随机推荐
- Xcode 下cocos-2dx 环境搭建
一.Cocos2d-x简介 Cocos2d-x是一个开源的移动2D游戏框架,MIT许可证下发布的,这是一个C++ Cocos2d-iPhone项目的版本. Cocos2d-X发展的重点是围绕Cocos ...
- Android万能的指示器
说到 ViewPager 指示器,想必大家都不陌生,绝大部分应用中都有这个.使用频率非常之高.但系统对它的支持并不好,自带的 PagerTabStrip 和 PagerTitleStrip 太弱,很难 ...
- OS X升级到10.11后Xcode6.4界面无iOS device选择栏的解决办法
原来在Xcode6.4项目运行按钮右侧会有一个可以选择设备或模拟器的选择栏,但是升级后没有了.但是Xcode7.0.1打开同样的项目会有显示. 简单找了一下无果后,发现咋Xcode顶部菜单里可以找到切 ...
- getJSONObject与optJSONObject的区别,结合源码分析
*json解析常见问题: getJSONObject与optJSONObject的区别,下面结合源码和案例来分析当我们使用这两周方法来解析数据时,哪种比较好. 源码分析: //使用getJSONObj ...
- 操作系统 - Linux进程实现的内部结构
在进程描述符中进入几个字段来表示进程之间的父子关系和兄弟关系. 图3-4显示了一组进程间的亲属关系. 表3-4:建立非亲属关系的进程描述符字段 在某些情况下,内核必须能从进程的PID到处对应的进程描述 ...
- 任务管理器中的PID找不到
PID是Process ID的简称,这对WINDOWS开发人员来说是非常有用的信息,但对于普通用户来说则根本不必去理会. 举个例子来说: 在网站发布的时候,需要安装IIS,那么iis的tcp的80 ...
- Struts2技术内幕 读书笔记一 框架的本质
本读书笔记系列,主要针对陆舟所著<<Struts2技术内幕 深入解析Strtus2架构设计与实现原理>>一书.笔记中所用的图片若无特殊说明,就都取自书中,特此声明. 什么是框架 ...
- 一键安装Android开发环境
一键安装Android开发环境 1 下载tadp-3.0r4-linux-x64.run 进入下面的地址下载: https://developer.nvidia.com/gameworksdownlo ...
- 给大家推荐一个python的学习网站 http://www.codecademy.com
注册之后,可以跟着指导,自己编码学习,比较方面: 再推荐一个在线编译的代码网站,c/c++ python 都可以: http://codepad.org
- rubygem若干常用选项参数
可以用gem help commands看所有支持的参数,这个比gem -h显示的全: wisy@wisy-ThinkPad-X61:~/src/ruby_src$ gem help commands ...