ES6学习笔记(5)----数值的扩展
参考书《ECMAScript 6入门》
http://es6.ruanyifeng.com/
数值的扩展
1.Number对象的扩展
(1)javascript的全局函数isNaN,isFinite,parseInt,parseFloat转为Number对象的函数
a. isNaN 与 Number.isNaN
相同点:都是用来判断数值是否是NaN
不同点:对于非数值的参数,isNaN会先用Number转化参数为数值类型,如果是NaN则返回true,如果不是,返回false;
而Number.isNaN,对于非数值的参数,一律返回false;
Number.isNaN('NaN') //false 非数值一律返回false
Number.isNaN(NaN) //true
isNaN('NaN') //true 非数值先转化成数值,然后再判断是否为NaN
isNaN(NaN) //true
b. isFinite 与 Number.isFinite
相同点:都用来判断数值是否有限
不同点:对于非数值的参数,isFinite会先用Number转化参数为数值类型,如果是有限的则返回true,如果不是,返回false;
而Number.isFinite,对于非数值的参数,一律返回false;
isFinite(1) //true
isFinite('1') //true 非数值先转换成数值,然后再判断是否有限
Number.isFinite(1) //true
Number.isFinite('1')//false 非数值一律返回false
c. parseInt 与 Number.parseInt 行为完全相同,parseFloat与Number.parseFloat 行为完全相同
(2)Number.isInteger 判断一个数值是否为整数
Number.isInteger(1) //true
Number.isInteger(1.0) //true
Number.isInteger(1.1)//false
如果参数的数值太大,十进制数转化成二进制数超过了53位,则不能保证准确性
(3)Number.EPSLION 常量(js能够表示的最小精度值 = 比1大的最小浮点数 - 1 = Math.pow(2,-52))
可用来做误差判断,如果计算结果小于这个误差,可以认为是无误差
(4)安全整数与Number.isSafeInteger
js 安全整数范围在-Math.pow(2,53)到 Math.pow(2,53)之间,超过这个范围就不准确了
Number.MAX_SAFE_INTEGER = 9007199254740991 = Math.pow(2,53) - 1
Number.MIN_SAFE_INTEGER = -9007199254740991 = - Math.pow(2,53) + 1 = - Number.MAX_SAFE_INTEGER
Number.isSafeInteger函数用来判断参数是否在此范围内
Number.isSafeInteger(Number.MAX_SAFE_INTEGER) //true
Number.isSafeInteger(Number.MAX_SAFE_INTEGER + 1) //false
Number.isSafeInteger(Number.MIN_SAFE_INTEGER) //true
Number.isSafeInteger(Number.MIN_SAFE_INTEGER - 1) //false
当Number.isSafeInteger是用来验证运算结果是否落在安全整数的范围内,不要只验证运算结果,而要同时验证参与运算的每个值,这样更准确
2.扩展的Math对象
Math.trunc() : 用于取得一个数的整数部分。如果参数是非数值,则先将参数转换成数值,再取整数部分,若是无法转化成数值的参数,则返回NaN
Math.trunc(1.23)//1
Math.trunc(1.78)//1
Math.trunc('')//0
Math.trunc(null)//0
Math.trunc('null')//NaN
Math.trunc(NaN)//NaN
Math.trunc('NaN')//NaN
Math.trunc(true)//1
Math.trunc('true')//NaN
Math.sign():用于返回一个数的符号为,若为正,则返回+1;若为负,则返回-1;若为0,则返回0;-0-->-0 +0--->+0;其他值返回NaN
Math.sign(123)//+1
Math.sign(-0.56)//-1
Math.sign(true)//+1
Math.sign(false) //+1
Math.sign(null) //0
参数为非数值时,会先转化成数值,再返回符号
Math.sign('')//0
Math.sign(true)//+1
Math.sign(false) //+1
Math.sign(null) //0
参数为非数值时,会先转化成数值,再返回符号,若无法转化成数值,则返回NaN
Math.sign('true') //NaN
Math.sign('false') //NaN
Math.sign('null') //NaN
Math.fround() : 用于返回一个数的32位单精度浮点数形式
Math.log10(X) : 返回以10为底的x的对数 X>0
Math.log2(X) :返回以2为底的x的对数 X>0
Math.hypot() : 返回所有参数的平方和的平方根
Math.hypot(3,4) // 5
Math.sinh()//双曲正弦
Math.cosh()//双曲余弦
Math.tanh()//双曲正切
Math.asinh()//双曲反正弦
Math.acosh()//双曲反余弦
Math.atanh()//双曲反正切
Math.imul() //返回两个整数相乘的结果(参数是32位的整数,结果也是32位的整数)
Math.clz32() //返回一个32位的整数有多少个前导0(不包含符号位)
1 == 00000000000000000000000000000001 // true
Math.clz32(1)//31
Math.clz32(00000000000000000000000000000001)//31
Math.cbrt() //返回参数的立方根
Math.cbrt(27) //3
Math.cbrt(8) //2
Math.log1p(x)//返回1+x的自然对数 Math.log1p(x) === Math.log(1+x) X>-1
Math.expm1(X)//e^x -1
ES6学习笔记(5)----数值的扩展的更多相关文章
- ES6学习笔记(三)——数值的扩展
看到这条条目录有没有感觉很枯燥,觉得自己的工作中还用不到它所以实在没有耐心看下去,我也是最近得闲,逼自己静下心来去学习去总结,只有在别人浮躁的时候你能静下心来去学去看去总结,你才能进步.毕竟作为前端不 ...
- es6学习笔记--字符串&数值&数组&函数&对象的扩展
这几天抽空学习了es6语法,关于字符串,数值,数组,函数以及对象的扩展,看到es6标准入门这本书,里面讲的扩展特别多,我认为有几部分在项目上用不到,就挑有用的当笔记学习了. 字符串的扩展 str.in ...
- es6学习笔记9--函数的扩展
函数参数的默认值 基本用法 在ES6之前,不能直接为函数的参数指定默认值,为了避免这个问题,通常需要先判断一下参数y是否被赋值,如果没有,再等于默认值. ES6允许为函数的参数设置默认值,即直接写在参 ...
- ES6 学习笔记之四 对象的扩展
ES6 为对象字面量添加了几个实用的功能,虽然这几个新功能基本上都是语法糖,但确实方便. 一.属性的简洁表示法 当定义一个对象时,允许直接写入一个变量,作为对象的属性,变量名就是属性名. 例1: , ...
- ES6学习笔记(一)——扩展运算符和解构赋值
前言 随着前端工程化的快速推进,在项目中使用ES6甚至更高的ES7等最近特性早已不是什么新鲜事.之前还觉得既然浏览器支持有限,那了解一下能看懂就好,然而仅仅了解还是不够的,现在放眼望去,那些成熟框架的 ...
- ES6学习笔记二:各种扩展
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/7242967.html 一:字符串扩展 1:字符串遍历器 for (let char of str) { // ...
- ES6学习笔记(8)----对象的扩展
参考书<ECMAScript 6入门>http://es6.ruanyifeng.com/ 对象的扩展 1.属性名的简洁表示法 : ES6允许在代码中直接写变量,变量名是属性名,变量值是属 ...
- Es6学习笔记(7)----数组的扩展
参考书<ECMAScript 6入门>http://es6.ruanyifeng.com/ 数组的扩展 1.扩展运算符:可以将数组转化成逗号隔离的单个参数...[1,2,3] //控制台运 ...
- ES6学习笔记(6)----函数的扩展
参考书<ECMAScript 6入门>http://es6.ruanyifeng.com/ 函数的扩展 函数的默认值 : ES6可以为函数指定默认值 (1)指定默认值的两种方式 a.函数参 ...
随机推荐
- 用secureCRT ssh登陆不显示用户名和路径解决方案 分类: 软件工具学习 2015-03-18 16:52 36人阅读 评论(0) 收藏
方法1 每次开始的时候输入 bash 虽然只能保存一次,但是简便. 方法2 用 vi ~/.bash_profile 编辑这个文件, 有时会提示这个文件不存在,直 ...
- 如何使用git 生成patch 和打入patch【转】
本文转载自:http://blog.csdn.net/liuhaomatou/article/details/54410361 平时我们在使用git 管理项目的时候,会遇到这样一种情况,那就是客户使用 ...
- POJ1077 Eight —— A*算法
主页面:http://www.cnblogs.com/DOLFAMINGO/p/7538588.html 关于A*算法:g(n)表示从起点到任意节点n的路径花费,h(n)表示从节点n到目标节点路径花费 ...
- jquery清空div里所有input输入框的值
$("#divId input").val("");
- html5--6-40 CSS边框
html5--6-40 CSS边框 实例 div动态阴影 学习要点 掌握CSS边框属性的使用 元素的边框就是围绕元素内容和内边距的一条或多条线. 元素的边框属性: border 简写属性,用于把针对四 ...
- docker容器安装使用
window安装 1 下载 http://mirrors.aliyun.com/docker-toolbox/windows/docker-toolbox/ docker toolbox 是一个 ...
- Excel: 使用Countif函数来去掉Excel中重复的数据
如果使用Ruby脚本,uniq函数就能搞定一切.不过我们现在还是讨论怎么用excel的Countif函数吧. 假设Excel中有一列数据:
- linux/unix下 pid文件作用浅析
l在linux系统的目录/var/run下面一般我们都会看到很多的*.pid文件.而且往往新安装的程序在运行后也会在/var/run目录下面产生自己的pid文件.那么这些pid文件有什么作用呢?它的内 ...
- Allure生成测试报告
Allure 使用 安装 adapter 如果要在 pytest 中使用 Allure,需要使用一个 Adaptor Allure Pytest Adaptor 安装 pytest-allure-ad ...
- 【转】[钉钉通知系列]Jenkins发布后自动通知
转载请注明出处:https://www.cnblogs.com/jianxuanbing/p/7211006.html 阅读目录 一.前言 二.使用钉钉推送的优势 三.配置 一.前言 最近使用Jenk ...