在项目开发中咱们常常会用到转型方法,尤为是JS这种松散型的语言。其中比较经常使用的方法就是Number()方法和ParseInt()/ParseFloat()方法了,下面咱们分别对这几种方法的转型机制进行详细地说明。设计
若是传入的参数为字符串,则遵循如下规则:code
若是字符串中只包含数字,则返回相应的数字值(前导的0会被忽略)对象
若是包含浮点和负号,则返回相应的小数或负数ip
若是是16进制数字,则返回相应的10进制数开发
若是包含空格,则开始和结束的空格会被忽略,若是中间包含空格则会返回NaN字符串
若是是空字符串,则返回0console
若是包含除去以上状况的其它字符,则返回NaN程序设计
若是传入的参数为true/false,则返回1/0程序
若是传入的参数为null,则返回0方法
若是传入的参数为undefined,则返回NaN
若是是数字,则简单的返回数字值
若是是对象,则调用对象的valueOf()方法,将所得值按照以上规则进行转型,若是获得NaN,再调用对象的toString()方法,将所得的值按以上规则进行转型
整体来讲Number()方法的转型机制比较复杂且难懂,通常咱们手动调用转型方法会使用parseInt()/parseFloat()方法进行转型,下面介绍这两个方法的转型机制。
若是传入的参数为字符串,则则从第0个位置开始,找到第一个非空格字符,若是第一个非空格字符不是数字或-号,则返回NaN,若是是数字或-号,则继续往下寻找,直到找到非数字字符,而后忽略后面的内容,返回前面找到的数字值(前导的空格会被忽略,中间的空格则会当成非数字字符处理)
若是是boolean,null,undefined类型值,则返回NaN
若是须要对8进制或者16进制的数进行转型,ECMAScript 3和ECMAScript 5有所不一样,因此推荐传入第二个参数,即进制数
若是是对象,则调用对象的toString()方法,将所得值再按照以上方法进行转型
*以上只说明了parseInt()方法的机制,parseFloat()方法与其只有一个区别,即parseFloat()方法遇到第一个浮点会继续往下寻找
下面举一些典型的例子,对以上机制进行验证和说明
console.log(Number("12a")); //NaN console.log(Number("")); //0 console.log(Number(null)); //0 console.log(Number(undefined)); //NaN console.log(Number(true)); //1 console.log(Number(false)); //0 console.log(Number([]); //0 console.log(parseInt("-1-2a")); //-1 console.log(parseInt("-a2a")); //NaN console.log(parseInt(" 12a")); //12 console.log(parseInt("1 2a")); //1 console.log(parseInt("")); //NaN console.log(parseInt(null)); //NaN console.log(parseInt(undefined));//NaN console.log(parseInt(true)); //NaN console.log(parseInt(false)); //NaN console.log(parseInt([])); //NaN
以上即是所总结的Number()和parseInt()/parseFloat()方法的转型机制,特别说明:大部分规则摘自《JavaScript高级程序设计第三版》。