在Javascript的世界里,一切都是对象。
但是某些对象还是和其他对象不太一样,为了区分对象的类型,我们用typeof操作符获取对象的类型,它总是返回一个字符串:
typeof 123;//'number'str
typeof NaN;//'number'
typeof 'str';//'string'
typeof true;//'boolean'
typeof undefined;//'undefined'
typeof Math.abs;//'function'
typeof null;//'object'
typeof [];//'object'
typeof {};//'object'
可见number,boolean,string,function和undefined有别于其他类型。特别注意null的类型是object,Array的类型也是object,如果我们用typeof将无法区分null,array和通常意义上的object——{}。
包装对象
除了这些类型外,Javascript还提供了包装对象.number,boolean,string都有包装对象,没错,在Javascript中,字符串也区分string类型和它的包装类型。包装对象用new创建:
var n = new Number(123);//123生成了新的包装类型
var b = new Boolean(true);//true 生成了新的包装类型
var s = new String('str');//'str'生成了新的包装类型
虽然包装对象看上去和原来的值一摸一样,显示出来也是一摸一样,但是他们的类型已经变成了object了!所以对象和原始值用===比较会返回false
typeof new Number(123); // 'object'
new Number(123) === 123; // false
typeof new Boolean(true); // 'object'
new Boolean(true) === true; // false
typeof new String('str'); // 'object'
new String('str') === 'str'; // false
所以不要使用包装对象!尤其针对string类型!!!
如果我们使用Number,Boolean,String时,不写new 会发生什么情况?
此时,Number(),Boolean,String被当作普通函数,把任意类型的数据转换为number,boolean和string类型
var n = Number('123'); // 123,相当于parseInt()或parseFloat()
typeof n; // 'number'
var b = Boolean('true'); // true
typeof b; // 'boolean'
var b2 = Boolean('false'); // true! 'false'字符串转换结果为true!因为它是非空字符串!
var b3 = Boolean(''); // false
var s = String(123.45); // '123.45'
typeof s; // 'string'
总结一下,有这么几条规则需要遵守:
1.不要使用new Number(),new String(),new Boolean()创建包装对象;
2.用parseInt()或parseFloat()来转换任意类型到number;
3.用string()来转换任意类型到string,或者直接调用某个对象的toString()方法;
4.通常不必把任意类型转为boolean再判断,因为可以直接写if (myVar){...};
5.typeof操作符可以判断出number,boolean,string,function和undefined
6.判断Array要使用Array.isArray(arr);
7.判断null请使用myVar === null;
8.判断某个全局变量是否存在用tyoepf window.myVar ==='undefined';
9.函数内部判断某个变量是否存在用typeof myVar === 'undefined'。
不是所有对象都有toString()方法,null和undefined就没有!
123.toString();//SyntaxError
遇到这种情况要处理
123..toString();
(123).toString();