JS中关于Number的用法
Posted lisser
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS中关于Number的用法相关的知识,希望对你有一定的参考价值。
number数字类型
包含:常规数字,NaN
NaN
not a number:不是一个数,但是他率属于数字类型
<script src = "test.js"></script>
//test.js
//console.log([val]):
//console.log("hello word!");
// ==:进行比较的
console.log(‘AA‘ == NaN);//false
console.log(10 == NaN);//false
console.log(NaN == NaN);//false
NaN和任何值(包括自己)都不相等:NaN!=NaN,所以我们不能用相等的方式判断是否为有效数字
isNaN
检测一个值是否为非有效数字,如果不是有效数字返回ture,反之是有效数字返回false
//isNaN([val])
console.log(isNaN[10]);//=>false
console.log(isNaN[‘AA‘]);//=>ture
//Number(‘AA‘) => NaN
//isNaN(NaN) => true
console.log(isNaN[‘10‘]);//=>false
//Number(‘10‘) => 10
//isNaN(10) => false
如果在使用isNaN进行有效数字检测的时候,首先会验证检测的值是否为数字类型,如果不是先基于Number()这个方法,把值转换为数字类型,然后再检测
把其它类型值转换为数字类型
把字符串转换为数字,只要字符串中包含任意一个非有效数字字符(第一个点除外)结果都是NaN,空字符串会变为数字零
- Number([val])
- parseInt/parseFloat([val],[进制]):也是转换为数字的方法,对于字符串来说,它是从左到右依次查找有效数字字符,直到遇到非有效数字字符,停止查找(不管后面是否还是数字,都不在找了),把找到的当作数字返回
console.log(Number(‘12.5‘));//=>12.5
console.log(Number(‘12.5px‘));//=>NaN
console.log(Number(1.5.5));//=>NaN
console.log(Number(‘‘));//空=>0
//布尔转换数字
console.log(Number(true));//=>1
console.log(Number(false));//=>0
console.log(isNaN(false));//=>false
//null->0 undefined->NaN
console.log(Number(null));//=>0
console.log(Number(undefined));//=>NaN
//把引用数据类型转换为数字,是先把他基于toString方法
console.log(Number({name:‘10‘}));//引用数据类型=>NaN
console.log(Number({}));//=>NaN
//{XX}.toString()=>"[object Object]"=>NaN
cosole.log(Number([]));=>0
//([]).toString() -> ‘‘
console.log(Number([12]))//=>12
//[12].toString(); -> ‘12‘
console.log(Number([12,23]));//=>NaN
//[12,23].toString() -> ‘12,23‘
let str = ‘12.5px‘;
console.log(Number(str));//=>NaN
console.log(parseInt(str));//=>12
console.log(pareInt(str));//=>12.5
console.log(pareFloat(‘width:12.5px‘));//=>NaN
以上是关于JS中关于Number的用法的主要内容,如果未能解决你的问题,请参考以下文章
JS 中关于Promise的用法,状态,执行顺序详解,面试可用(原创)
想知道JS中关于function(e)事件;中的参数e的用法意义;
c#中关于splitContainer控件的用法:如何做到不清除控件就能在panel2中打开一个窗体呢?