JavaScript标准对象_动力节点Java学院整理
在JavaScript的世界里,一切都是对象。
但是某些对象还是和其他对象不太一样。为了区分对象的类型,我们用typeof操作符获取对象的类型,它总是返回一个字符串:
typeof123;//'number' typeofNaN;//'number' typeof'str';//'string' typeoftrue;//'boolean' typeofundefined;//'undefined' typeofMath.abs;//'function' typeofnull;//'object' typeof[];//'object' typeof{};//'object'
可见,number、string、boolean、function
包装对象
除了这些类型外,JavaScript还提供了包装对象,熟悉Java的小伙伴肯定很清楚int和Integer这种暧昧关系。
number、boolean和string都有包装对象。没错,在JavaScript中,字符串也区分string类型和它的包装类型。包装对象用new创建:
varn=newNumber(123);//123,生成了新的包装类型 varb=newBoolean(true);//true,生成了新的包装类型 vars=newString('str');//'str',生成了新的包装类型
虽然包装对象看上去和原来的值一模一样,显示出来也是一模一样,但他们的类型已经变为object了!所以,包装对象和原始值用===比较会返回false:
typeofnewNumber(123);//'object' newNumber(123)===123;//false typeofnewBoolean(true);//'object' newBoolean(true)===true;//false typeofnewString('str');//'object' newString('str')==='str';//false
所以闲的蛋疼也不要使用包装对象!尤其是针对string类型!!!
如果我们在使用Number、Boolean
此时,Number()、Boolean和String()被当做普通函数,把任何类型的数据转换为number、boolean和string类型(注意不是其包装类型):
varn=Number('123');//123,相当于parseInt()或parseFloat() typeofn;//'number' varb=Boolean('true');//true typeofb;//'boolean' varb2=Boolean('false');//true!'false'字符串转换结果为true!因为它是非空字符串! varb3=Boolean('');//false vars=String(123.45);//'123.45' typeofs;//'string'
是不是感觉头大了?这就是JavaScript特有的催眠魅力!
总结一下,有这么几条规则需要遵守:
- 不要使用newNumber()、newBoolean()、newString()创建包装对象;
- 用parseInt()或parseFloat()来转换任意类型到number;
- 用String()来转换任意类型到string,或者直接调用某个对象的toString()方法;
- 通常不必把任意类型转换为boolean再判断,因为可以直接写if(myVar){...};
- typeof操作符可以判断出number、boolean、string、function和undefined;
- 判断Array要使用Array.isArray(arr);
- 判断null请使用myVar===null;
- 判断某个全局变量是否存在用typeofwindow.myVar==='undefined';
- 函数内部判断某个变量是否存在用typeofmyVar==='undefined'。
最后有细心的同学指出,任何对象都有toString()方法吗?null和undefined就没有!确实如此,这两个特殊值要除外,虽然null还伪装成了object类型。
更细心的同学指出,number对象调用toString()报SyntaxError:
123.toString();//SyntaxError
遇到这种情况,要特殊处理一下:
123..toString();//'123',注意是两个点! (123).toString();//'123'
不要问为什么,这就是JavaScript代码的乐趣!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。