Javascript显示和隐式类型转换
1.转换成字符串
多数的JavaScript宿主环境(比如Node.js和Chrome)都提供了全局函数toString
; 与此同时Object.prototype
也定义了toString
方法,使得所有对象都拥有转换为字符串的能力。
比如一个Number
转换为String
:
var n = 1; n.toString(); // '1'
toString
接受一个参数指定进制,默认为10. 可以利用这个参数生成包括字母和数字的随机字符串:
Math.random().toString(36).substr(2);
random
生成一个0到1的随机数,36进制的字符集为[0-9a-z]
(36个),substr
用来截掉起始的"0."
。 另外Object.prototype.toString
可以用来检测JavaScript对象的类型:
var toString = Object.prototype.toString; toString.call(new Date); // [object Date] toString.call(new String); // [object String] toString.call(Math); // [object Math] // Since JavaScript 1.8.5 toString.call(undefined); // [object Undefined] toString.call(null); // [object Null] // 自定义类型 toString.call(new MyClass); // [object Object]
2.转换为数字
字符串转换为数字也是常见需求,通常用来从用户输入或文件来获得一个Number,
在JavaScript中可以直接用parseInt
和parseFloat
。 例如:
var iNum1 = parseInt("12345red"); //返回 12345 var iNum1 = parseInt("0xA"); //返回 10 var iNum1 = parseInt("56.9"); //返回 56 var iNum1 = parseInt("red"); //返回 NaN var fNum4 = parseFloat("11.22.33"); //返回 11.22
注意NaN
是JavaScript中唯一一个不等于自己的值。(NaN == NaN) === false
! 如果遇到非法字符,parseInt
和parseFloat
会忽略之后的所有内容。
parseFloat
只接受十进制数字的字符串,而parseInt
还提供了第二个参数(可选)用来指定字符串表示数字的进制:
var iNum1 = parseInt("10", 2); //返回 2 var iNum2 = parseInt("10", 8); //返回 8 var iNum3 = parseInt("10", 10); //返回 10
3.强制类型转换
Boolean(0) // => false - 零 Boolean(new object()) // => true - 对象 Number(undefined) // => NaN Number(null) // => 0 String(null) // => "null"
4.隐式类型转换
隐式类型转换是最为隐蔽的地方,不加注意的话很容易在这一点上出错,对这一点的掌握也体现了JavaScript程序员经验。 JavaScript会自动转换表达式中对象的类型以完成表达式求值。
四则运算
加法运算符+
是双目运算符,只要其中一个是String
类型,表达式的值便是一个String
。
对于其他的四则运算,只有其中一个是Number
类型,表达式的值便是一个Number
。
对于非法字符的情况通常会返回NaN
:
'1' * 'a' // => NaN,这是因为parseInt(a)值为NaN,1 * NaN 还是 NaN
判断语句
判断语句中的判断条件需要是Boolean
类型,所以条件表达式会被隐式转换为Boolean
。 其转换规则同Boolean
的构造函数。比如:
var obj = {}; if(obj){ while(obj); }
Native代码调用
JavaScript宿主环境都会提供大量的对象,它们往往不少通过JavaScript来实现的。 JavaScript给这些函数传入的参数也会进行隐式转换。例如BOM提供的alert
方法接受String
类型的参数:
alert({a: 1}); // => [object Object]