parseInt()
- parseInt用于将字符串转为整数
- 值得注意的是,转为整数的时候,是一个个字符顺次转换,如果遇到不能转为数字的字符,就不再进行上来,而是返回曾经转好的局部。
parseInt('8a') // 8parseInt('12**') // 12parseInt('12.34') // 12parseInt('15e2') // 15parseInt('15px') // 15
若第一个字符不能转换为数字(正负号除外),返回NaN。
parseInt('abc') // NaNparseInt('.3') // NaNparseInt('') // NaNparseInt('+') // NaNparseInt('+1') // 1
综上,parseInt要么返回一个十进制整数,要么返回NaN
- 另外,如果字符串以
0x
或0X
结尾,parseInt
会将其依照十六进制数解析。
parseInt('0x10') // 16
如果字符串以0
结尾,将其依照10进制解析。
parseInt('011') // 11
对于那些会主动转为迷信计数法的数字,parseInt
会将迷信计数法的示意办法视为字符串,因而导致一些奇怪的后果。
parseInt(1000000000000000000000.5) // 1// 等同于parseInt('1e+21') // 1parseInt(0.0000008) // 8// 等同于parseInt('8e-7') // 8
parseInt还能够用于进制转换
parseInt
办法还能够承受第二个参数(2到36之间),示意被解析的值的进制,返回该值对应的十进制数。默认状况下,parseInt
的第二个参数为10,即默认是十进制转十进制。
parseInt('1000', 2) // 8parseInt('1000', 6) // 216parseInt('1000', 8) // 512
- 值的留神的是,若第二个参数不是数值,会被主动转为一个整数。这个整数只有在2到36之间,能力失去有意义的后果,超出这个范畴,则返回
NaN
。如果第二个参数是0
、undefined
和null
,则间接疏忽。
parseInt('10', 37) // NaNparseInt('10', 1) // NaNparseInt('10', 0) // 10parseInt('10', null) // 10parseInt('10', undefined) // 10
若字符串蕴含对于指定进制无意义的字符,则从最高位开始,只返回能够转换的数值。如果最高位无奈转换,则间接返回NaN
。
parseInt('1546', 2) // 1parseInt('546', 2) // NaN
parseFloat()
- 用于将一个字符串转换为浮点数
- 值得注意的是,也是从头一个个进行转换,遇到不能转为浮点数的字符,则不再进行往后转换,返回曾经转好的局部。
parseFloat('3.14more non-digit characters') // 3.14
与parseInt不同,parseFloat能够进行迷信计数法的转换
parseFloat('314e-2') // 3.14parseFloat('0.0314E+2') // 3.14
与parseInt能够将数字转换为字符串不同,parseFloat必须是字符串。若参数不是字符串,或第一个字符不能转换为浮点数,返回NaN
parseFloat([]) // NaNparseFloat('FF2') // NaNparseFloat('') // NaN
这些特点使得parseFloat
的转换后果不同于Number
函数。
parseFloat(true) // NaNNumber(true) // 1parseFloat(null) // NaNNumber(null) // 0parseFloat('') // NaNNumber('') // 0parseFloat('123.45#') // 123.45Number('123.45#') // NaN
isNaN()
- 能够判断一个值是否为NaN
- 值得注意的是,此函数只对数值无效,所以当传入字符串时,会返回true。所以,isNaN为true的值,可能并不是NaN,而只是一个字符串、对象或者数组
isNaN('Hello') // true// 相当于isNaN(Number('Hello')) // true
然而,对于空数组和只有一个数值成员的数组,函数返回false。这是因为这样的数组能够被Number函数转为数值
isNaN([]) // falseisNaN([123]) // falseisNaN(['123']) // false
- 因而,应用isNaN函数前,最好判断下数据类型
function myIsNaN(value) { return typeof value === 'number' && isNaN(value);}
或者,利用NaN为惟一不等于本身值的这一个性
function myIsNaN(value) { return value !== value;}
isFinite()
isFinite
办法返回一个布尔值,示意某个值是否为失常的数值。
isFinite(Infinity) // falseisFinite(-Infinity) // falseisFinite(NaN) // falseisFinite(undefined) // falseisFinite(null) // trueisFinite(-1) // true
除了Infinity
、-Infinity
、NaN
和undefined
这几个值会返回false
,isFinite
对于其余的数值都会返回true
。