JavaScript 标准对象
来源:互联网 发布:上海旋转餐厅知乎 编辑:程序博客网 时间:2024/05/18 03:02
在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; // falsetypeof new Boolean(true); // 'object'new Boolean(true) === true; // falsetypeof 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'); // truetypeof b; // 'boolean'var b2 = Boolean('false'); // true! 'false'字符串转换结果为true!因为它是非空字符串!var b3 = Boolean(''); // falsevar 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代码的乐趣!
- javascript标准对象
- JavaScript 标准对象
- JavaScript中的标准对象
- JavaScript(五)标准对象
- JavaScript基础之标准对象
- JavaScript标准对象(笔记)
- javascript标准对象与包装对象
- JavaScript学习笔记十八:标准对象-Date
- JavaScript学习笔记十九:标准对象-RegExp
- JavaScript 从标准对象开始--20160930
- JavaScript标准对象中注意点
- javascript学习(十三)— 标准对象
- JavaScript基础系列之三 标准对象
- JavaScript标准对象的一点规则
- JavaScriptのDOM中的事件对象(W3C标准)
- JavaScript学习笔记二十:标准对象-JSON
- 标准对象
- 【JavaScript】JavaScript标准阐述
- A Convolutional Neural Network Cascade for Face Detection
- 理解show engine innodb status之LOG
- HDU-2045 不容易系列之(3)—— LELE的RPG难题(动态规划)
- 如何在图片中添加数字编号?
- APP自动化框架LazyAndroid使用手册(3)--核心API介绍
- JavaScript 标准对象
- python3 如何读写配置文件(ini)
- How to install linux with a usb device
- Deeply learned face representations are sparse, selective, and robust
- Android消息机制Handler源码简单解析
- UVa 10810 Ultra-QuickSort(逆序对)
- activiti获取启动流程的图片和xml
- javaWeb之Servlet
- Android详情页+定位评论区