ES6—数值(Number,Math对象)(复习+学习)

每天一学,今天要学习ES6的关于数的扩展以及复习,然后通过看书,查阅资料,以及webAPI来搞清楚遇到的,没见过的对象方法等等,下面为本次学习的笔记分类:

1.数值(表示)

2.Number对象

3.Math对象

4.总结

1.数值(表示)

1 //ES6 提供了二进制和八进制的写法(0b ||0o),0b 为二进制,0o为八进制。
2 //ES6与ES5中,ES5不许使用前缀0表示八进制,而ES6允许
3 //如果要将二或者八进制的数转化为十进制,可以使用Number对象
4 Number('0b111') //7
5 Number('0o10') //8
6 //十进制转化为其他进制(2)等等,利用num.toString('x');
7 let a = 2;
8 console.log(a.toString(2)); //10

2.Number对象

2.1 Number.isFinite(),Number.isNaN()

 1 //(1)Number.isFinite()与 全局isFinite()方法
2 //Number.isFinite() 为Number对象的一种方法,isFinite() 是全局方法,两者的目的都是为了判断一个数值是否有穷
3 ​
4 //用法区别:
5 //Number.isFinite()
6 Number.isFinite(value);
7 //全局isFinite()方法
8 isFinite(testValue)
9 ​
10 //差别:
11 Number.isFinite(value); //中的value只能是一个数值型的值,如果是字符串的数字,就会直接返回false
12 isFinite(testValue) //如果参数是一个字符串,可以先强转为数值,再进行测试
13 ​
14 isFinite("115"); //true
15 Number.isFinite("115") //false

//(2)Number.isNaN() 与 全局isNaN()
//Number.isNaN() 方法确定传递的值是否为 NaN,并且检查其类型是否为 Number,更加稳妥。
//isNaN() 只检查一个值是否为NaN

//区别用法看一个例子
isNaN(NaN);   //true
isNaN("NaN");   //true
Number.isNaN(NaN);  //true
Number.isNaN("NaN");  //false
 






2.2 Number.parseInt()与Number.parseFloat()

1 //传统的有parseInt(),parseFloat()方法,但是ES6将这两个方法放到Number对象里了,用法不变,ES6新增了模块化的概念,这样才做更利于模块化
2 ​
3 //(1)Number.parseInt() 方法依据指定基数 [ 参数 radix 的值],把字符串 [ 参数 string 的值] 解析成整数。
4 // Number.parseInt === parseInt; // true,表示两个用法一样
5 Number.parseInt(string[, radix]); // string 表示一个字符串 radix 表示表示半径(数学数值系统的基数)(了解)
6 console.log(Number.parseInt(12.25266)); //数值为非字符串的话,会调用toString方法转化,返回一个整值
7 ​
8 //(2)Number.parseFloat() 方法可以把一个字符串解析成浮点数
9 Number.parseFloat(string)

2.3 Number.isInteger()

 1 //用于判断一个数是否为整数,js中整数和浮点数的存储方法相同,因此3.0和3结果一样 2 ​ 3 number.isInteger(15.1) //false 

2.4 Number.EPSILON

 1 //仅仅表示一个极小值常量,用于判断误差范围,如果在该属性值范围内,则可以认为得到了正确答案 

  2.5 Number.isSafeInteger()  

1 //Number.isSafeInteger()方法用来判断传入的参数值是否是一个“安全整数”(safe integer)。
2 Number.isSafeInteger(testValue) //参数为要测试的值 返回一个布尔值
3 Number.isSafeInteger(3); // true
4 Number.isSafeInteger(Math.pow(2, 53)) // false

3.Math对象

  3.1 Math.trunc()

1 //Math.trunc() 方法会将数字的小数部分去掉,只保留整数部分。
2 Math.trunc(value) //value 可以取数字,返回值
3 //demo
4 Math.trunc(13.37) // 13
5 Math.trunc(42.84) // 42

3.2 Math.sign()

 1 //判断数值的种类(非数值会转化为数值)
2 Math.sign(x);
3 ​
4 //demo
5 Math.sign(3); // 1 整数返回 1
6 Math.sign(-3); // -1 复数返回-1
7 Math.sign("-3"); // -1
8 Math.sign(0); // 0 0 返回 0
9 Math.sign(-0); // -0 -0 返回-0
10 Math.sign(NaN); // NaN 非数值返回NaN

3.3 Math.cbrt()

 1 //Math.cbrt() Math.cbrt() 函数返回任意数字的立方根.非数值也会先转化为数字再操作 2 Math.cbrt(x) 3 Math.cbrt(4) //1.5874010519681996 

3.4 Math.clz32() 与 Math.imul()

1 //把这两个放一起是因为这两个都是32进制操作的,了解一下就行了,具体自行查阅
2 // Math.clz32() 函数返回一个数字在转换成 32 无符号整形数字的二进制形式后, 开头的 0 的个数, 比如 1000000 转换成 32 位无符号整形数字的二进制形式后是 00000000000011110100001001000000, 开头的 0 的个数是 12 个, 则 Math.clz32(1000000) 返回 12
3 //Math.imul() 方法返回两个数以32位带符号形式相乘的结果

3.5 Math.fround()

1 //Math.fround() 方法返回一个数的单精度浮点数形式
2 Math.fround() //0
3 Math.fround(1.337) // 1.3370000123977661

3.6 Math.hypot()

1 //Math.hypot() 函数返回所有参数的平方和的平方根
2 Math.hypot([value1[,value2, ...]]) //value1, value2, ...任意个数字,将所提供的参数求平方和后开平方根。如果有参数不能转换为数字,则返回 NaN。。
3 Math.hypot(3, 4); // 5

4.总结

本次大概学习了数值,对象方法,这些内容,我感觉有些常用的需要记忆一下,有些只需要了解一下,还有对数,双曲线,新增了一个指数运算**,等等内容可以自行查阅文档。继续努力!!

ES6—数值(Number,Math对象)(复习+学习)的更多相关文章

  1. 第一百零八节,JavaScript,内置对象,Global对象字符串编码解码,Math对象数学公式

    JavaScript,内置对象,Global对象字符串编码解码,Math对象数学公式 学习要点: 1.Global对象 2.Math对象 ECMA-262对内置对象的定义是:"由ECMASc ...

  2. es6学习笔记--字符串&数值&数组&函数&对象的扩展

    这几天抽空学习了es6语法,关于字符串,数值,数组,函数以及对象的扩展,看到es6标准入门这本书,里面讲的扩展特别多,我认为有几部分在项目上用不到,就挑有用的当笔记学习了. 字符串的扩展 str.in ...

  3. ES6(四) --- 正则 Number Math

    想学vue了  重启ES6的学习之路 在ES5 中正则的构造器  RegExp  不支持第二个参数 ES6 做了调整   第二个参数表示正则表达式的修饰符(flag) var regex = new ...

  4. Java 学习(6):java Number & Math & String & 数组...常用类型

    目录 --- Number & Math类 --- Character 类 --- String 类 --- StringBuffer 类 --- 数组 Number & Math类: ...

  5. ES6 对Math对象的扩展

    Math 对象的扩展 Math.trunc() Math.trunc(4.1) // 4 Math.trunc(4.9) // 4 Math.trunc(-4.1) // -4 Math.trunc( ...

  6. 数值(Number,Math, 运算符)

    1.js中数字 1.数字存储 Javascript中所有数字的存储都是64位浮点数.整数也一样. 1 === 1.0 // true 2. 数字大小范围 可以表示的最大正数和最小负数 (-Math.p ...

  7. ES6 之 Math对象的扩展

    1.ES5 http://www.w3school.com.cn/jsref/jsref_obj_math.asp 2.ES6 Math.trunc() - 取整,去掉一个数的小数部分 console ...

  8. JS学习笔记10之Math对象

    -->Math对象 常用属性和方法-->使用Math对象制作相应的效果 Math对象用于执行数学任务 一.Math对象的属性: 二.Math对象的方法: 三.常用属性和方法: Math.P ...

  9. JavaScript中Date(日期对象),Math对象--学习笔记

    Date对象 1.什么是Date对象? 日期对象可以储存任意一个日期,并且可以精确到毫秒数(1/1000 秒). 语法:var Udate=new Date();  注:初始值为当前时间(当前电脑系统 ...

随机推荐

  1. "错误: 找不到或无法加载主类"解决办法

    前言:记上次一个找了个把小时的问题(很烦这些配置) 原因: 从svn下checkOut的项目 在application的配置的输出class路径为main,而class文件路径是在项目名的根路径下,所 ...

  2. Redis之品鉴之旅(七)

    分布式锁 1)阻塞锁: 尝试在redis中创建一个字符串结构缓存,方法传入的key,value为锁的过期时间timeout的时间戳. 若redis中没有这个key,则创建成功(即抢到锁),然后立即返回 ...

  3. Spring配置文件结构对于生成Bean的影响

    Spring配置文件结构对于生成Bean的影响 有段时间忙于毕设,导致Spring学习的东西忘了很多,所以最近又开始从头看Spring的基础.基础的Bean的装配不再多说了.这一次,主要是深入一点了解 ...

  4. TypeScript 枚举指南

    枚举是受 TypeScript 支持的数据类型.枚举允许您定义一组命名常量.使用它们可以更轻松地记录意图或创建一组不同的案例.枚举大多数用于面向对象的编程语言(如 Java 和 C#)中,现在也可以 ...

  5. AT3950 [AGC022E] Median Replace

    题目传送门 Description 有一个长度为 \(n\) 的 \(01\) 串,里面有一些还没有确定,我们标记为 ? .可以进行若干次操作,每次操作可以把三个相邻的数替换成它们的中位数.问有多少种 ...

  6. 八大排序算法之基数排序(python实现)

    [写在前面] 参考文章: https://blog.csdn.net/nrsc272420199/article/details/82691596[给出的示例图,简单易懂,但是对于没一轮循环没有讲解的 ...

  7. 10-1 Python 学习笔记

    1. 项目 在文本编辑器中新建一个文件,写几句话来总结一下你至此学到的 Python 知识,其中每一行都以"In Python you can"打头. 将这个文件命名为learni ...

  8. 三分钟极速体验:Java版人脸检测

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  9. JuiceFS 如何帮助趣头条超大规模 HDFS 降负载

    作者简介 王振华,趣头条大数据总监,趣头条大数据负责人. 王海胜,趣头条大数据工程师,10 年互联网工作经验,曾在 eBay.唯品会等公司从事大数据开发相关工作,有丰富的大数据落地经验. 高昌健,Ju ...

  10. 【二食堂】Beta - Scrum Meeting 9

    Scrum Meeting 9 例会时间:5.24 20:00~20:20 进度情况 组员 当前进度 今日任务 李健 1. 文本导入.保存部分未完成issue 2. 知识图谱导出的前端issue3. ...