JavaScript标准对象_动力节点Java学院整理
在javascript的世界里,一切都是对象。
但是某些对象还是和其他对象不太一样。为了区分对象的类型,我们用typeof操作符获取对象的类型,它总是返回一个字符串:
typeof 123; // 'number' typeof nan; // 'number' typeof 'str'; // 'string' typeof true; // 'boolean' typeof undefined; // 'undefined' typeof math.abs; // 'function' typeof null; // 'object' typeof []; // 'object' typeof {}; // 'object'
可见,number、string、boolean、function和undefined有别于其他类型。特别注意null的类型是object,array的类型也是object,如果我们用typeof将无法区分出null、array和通常意义上的object——{}。
包装对象
除了这些类型外,javascript还提供了包装对象,熟悉java的小伙伴肯定很清楚int和integer这种暧昧关系。
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'
是不是感觉头大了?这就是javascript特有的催眠魅力!
总结一下,有这么几条规则需要遵守:
- 不要使用new number()、new boolean()、new string()创建包装对象;
- 用parseint()或parsefloat()来转换任意类型到number;
- 用string()来转换任意类型到string,或者直接调用某个对象的tostring()方法;
- 通常不必把任意类型转换为boolean再判断,因为可以直接写if (myvar) {...};
- typeof操作符可以判断出number、boolean、string、function和undefined;
- 判断array要使用array.isarray(arr);
- 判断null请使用myvar === null;
- 判断某个全局变量是否存在用typeof window.myvar === 'undefined';
- 函数内部判断某个变量是否存在用typeof myvar === 'undefined'。
最后有细心的同学指出,任何对象都有tostring()方法吗?null和undefined就没有!确实如此,这两个特殊值要除外,虽然null还伪装成了object类型。
更细心的同学指出,number对象调用tostring()报syntaxerror:
123.tostring(); // syntaxerror
遇到这种情况,要特殊处理一下:
123..tostring(); // '123', 注意是两个点! (123).tostring(); // '123'
不要问为什么,这就是javascript代码的乐趣!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
apache简介_动力节点Java学院整理
-
Spring MVC之DispatcherServlet详解_动力节点Java学院整理
-
Spring MVC之DispatcherServlet_动力节点Java学院整理
-
linux下安装memcached_动力节点Java学院整理
-
Apache和Tomcat有什么区别_动力节点Java学院整理
-
JavaScript之RegExp_动力节点Java学院整理
-
JavaScript原型继承_动力节点Java学院整理
-
JavaScript之underscore_动力节点Java学院整理
-
JavaScript之DOM_动力节点Java学院整理
-
JavaScript之promise_动力节点Java学院整理