js标准对象

在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还提供了包装对象。number、boolean和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

        type new String('str');//'object'
        new String('str') === 'str';//false

如果我们在使用Number、Boolean和String时,没有写new会发生什么情况?

此时,Number()、Boolean和String()被当做普通函数,把任何类型的数据转换为number、boolean和string类型。

几条规则需要遵守:

  • 不要使用new Number()new Boolean()new String()创建包装对象;

  • parseInt()parseFloat()来转换任意类型到number

  • String()来转换任意类型到string,或者直接调用某个对象的toString()方法;

  • 通常不必把任意类型转换为boolean再判断,因为可以直接写if (myVar) {...}

  • typeof操作符可以判断出numberbooleanstringfunctionundefined

  • 判断Array要使用Array.isArray(arr)

  • 判断null请使用myVar === null

  • 判断某个全局变量是否存在用typeof window.myVar === 'undefined'

  • 函数内部判断某个变量是否存在用typeof myVar === 'undefined'

最后有细心的同学指出,任何对象都有toString()方法吗?nullundefined就没有!确实如此,这两个特殊值要除外,虽然null还伪装成了object类型。

更细心的同学指出,number对象调用toString()报SyntaxError:

123.toString(); // SyntaxError

 特殊处理:

123..toString(); // '123', 注意是两个点!
(123).toString(); // '123'
原文地址:https://www.cnblogs.com/yuanxinru321/p/7711861.html