Js的数字数据类型有两种,一种是使用IEEE745格式来表示的数值型,存储的最大范围在2的正负53次方之间,也是我们经常使用的类型,还有一种是BigInt类型,用来存储任意类型的数字,但是用的地方不多,我们主要学习第一种常用数字类型。
一、字面量格式的表示方法
1、十进制:十进制整数可以直接像数学中一样书写,也是我们日常开发中最常用的一种进制,例如:let num = 10;
2、八进制:ECMAJavascript规定,八进制字面值的第一位必须是0,如果我们书写的数值超出了八进制的范围,那么0将会被浏览器忽略,后面的数值将会被当作十进制来解析(八进制的范围是0-7)。需要注意的是,在严格模式下,八进制如果超出书写的范围会报错。例如:
严格模式下报错:
3、十六进制
十六进制的前两位必须是0x,后面跟着的是十六进制数字(0-9以及A-F,字母可以是大写也可以是小写);例如:
说明:(1)、在进行算术计算时,我们书写的八进制和十六进制都会转换为十进制。
(2)、我们在书写十进制的时候,ke可能有时候会遇到有很多0的情况,数0数的眼花不说,还容易乱,在js中提供了一种简单的写法,用e表示,例如:9.7e7表示的是9.7乘以10的7次幂,如果是-7的话就是10的-7次幂。是不是感觉简单多了。
(3)、十六进制的使用一般是表示颜色值,例如:0xFF;
二、浮点数值
浮点数值,书写的数值中必须包含小数点而且小数点后面必须有一位,但是需要注意的是,保存浮点数的值需要的内存空间是整数的2倍,因此ECMAJavascript是不会放过任何一个可以将浮点型转换为整型的机会,如果你的项目中规定必须使用小数,就要注意一下。
说明:1、不要使用js做比较精确的数值运算,那样你会疯掉的,不相信你可以试试使用js计算一下0.1+0.2的值,绝对不是0.3,这是由于数字的存储序列的问题,
有个解决的办法就是使用toFixed( n )对结果进行取舍。
2、js常用的取舍内置函数;
(1)、Math.toFixed(n);向下取舍,n值代表的是小数的位数,返回值是一个字符串,如果返回的小数位不足,用0补齐。例如:1.1变成1,-1.1变成-2;
(2)、Math.ceil(n);向上取舍,例如:1.1变成2,-1.1变成-1;
(3)、Math.round(n);四舍五入,
三、NAN
NAN即非数,是js数值型里面的一个特殊值,经常用来表示一个原设定要返回数值的操作未返回数值,这也体现了js的灵活性,这样做就不会报错,不会阻止后续程序的执行。
说明:(1)、凡是涉及到NAN的计算最终的结果都是NAN,NAN最狠的是连自己也不认识,即NAN不等于任何值,包括其自身。
(2)、鉴于以上情况,js用isNAN( )来判断我们输入的值是不是NAN,返回的结果是一个布尔值。
四、两个内置的转换函数
1、转换为整型parseInt( );
处理整数时常用的转换函数;会忽略字符串前面的空格,直至找到第一个非空格字符,
转换规则:
a、如果第一个非空格字符不是数字或者负号,就会返回NAN;与number不同的是,需要注意的是number会将空字符串转换成0,但是parseInt()会转换为NAN;
b、如果第一个字符是数字,会继续解析第二个字符,直到遇到非数字字符停止,然后将前面读取到的数值返回,例如parseInt(“123456abc”),转换的结果为123456,由于parseInt()是整型函数,会忽略小数点以后的数字字符,例如:parseInt(123.5),结果是123;
c:特别需要注意的是在parseInt()转换中,如果字符串是以ox开头且后面跟着数字字符,会被当作十六进制数来处理,字符串以0开头会被当作八进制处理;例如:parseInt(“oxf”),结果是15;(如果不会进制转换,建议先去百度学习一下)!
d、在js老版本中,会发生进制混乱的情况,为了解决这一问题,可以为parseInt()提供第二个参数,例如parseInt(“oxf”,16)明确指出为16进制,避免了错误的解析;建议在书写时指定进制,以免出现解析失败的情形。
2、转换为浮点型parseFloat( );
a、特别注意一点:parseFloat()只能转换十进制数值,永远没有第二个参数的写法,如果书写了八进制或者十六进制,八进制被当作十进制处理,十六进制会被转换成0;例如parseFloat(oxf)转换的结果是0;
b、parseFloat()只识别第一个小数点,第二个小数点是无效的;例如:parseFloat(123.5.6),转换的结果是123.5;
c、parseFloat()也可以采用科学计数法的方式书写,书写方法为parseFloat(3.125e7),转换的结果是31250000;e代表科学计数法当中的10;
3、转换为数值型Number( );
程序会从左到右去挨个读取number里面的值,直到遇到一个非数字类型的值停止;
Number转换规则:
a、如果第一个数字是0,程序会直接忽略数字0,直接读取下一个数字;例如:number(0123),其结果是123;
b、如果第一个是非数,直接返回NAN,例如:number(a122);结果是NAN;当一个数字是0,第二个数字是非数时,返回的结果也是NAN;如果以数字开头,但是包含字母、下划线等,会直接返回NAN.例如:number(“1123abc”)结果是NAN;但是小数点会当作浮点类型处理,不会停止程序运行,例如:number(123.05),结果是123.05;
c、如果是空字符串则返回0;例:Number(“”);结果为0;引号之间添加空格或者书写数字0其结果相同;
d、如果转换的是布尔值,true和false将分别被转换为1和0;
e、如果是null,返回0;如果是undefined,返回NAN;
f、如果字符串中包含有效的十六进制格式,例如number(oxf);会先将其转换为大小相同的十进制整数值;其中ox是十六进制的标识符,转换结果为15;
好了,今天的内容基本上完了,今天的任务是完成以下测试(图片来自腾讯课堂渡一教育):
声明:本文部分素材转载自互联网,如有侵权立即删除 。
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 精力有限,不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别
丞旭猿论坛
暂无评论内容