zoukankan      html  css  js  c++  java
  • 内部属性[[Class]]

    对象的内部属性

    所有typeof返回值为“object”的对象(如数组)都包含一个内部属性[[class]],这个属性无法直接访问,一般通过Object.prototype.toString(..)来查看。

    console.log(Object.prototype.toString.call([1,2,3]));  //[object Array]
    
    console.log(Object.prototype.toString.call(/d/));    //[object RegExp]

    基本数据类型的内部属性

    然Null()和Undefined()这样的原生构造函数并不存在,但是内部[[class]]属性仍然是“Null”和“Undefined”。

     console.log(Object.prototype.toString.call(null)); //[object Null]
    
     console.log(Object.prototype.toString.call(undefined)); //[object Undefined]

    其他类型

    console.log(Object.prototype.toString.call("abc")); //[object String]
    
    console.log(Object.prototype.toString.call(42));  //[object Number]
    
    console.log(Object.prototype.toString.call(true)); //[object Boolean]

    基本类型值被各自的封装对象自动包装,所以他们的内部[[class]]属性分别为“String”,“Number”和“Boolean”。

    封装对象

    由于基本类型值没有.length和.toString()这样的属性和方法,需要通过封装对象才能访问,此时Javascript引擎会自动为基本类型值包装一个封装对象。

     //封装对象包装
     var b = 'abc';
     console.log(b.length); //3
     console.log(b.toUpperCase()); //abc

    一般不直接使用封装对象(即通过new操作创建基本类型值),优先考虑使用“abc”和“42”这样的基本类型值,而不是new String("abc") 和 new Number(42)。

    拆封

    如果想要得到封装对象中的基本类型值,可以使用valueOf()函数。

    //封装对象的拆封
    var s = new String( "abc" );
    var n = new Number( 42 );
    var b = new Boolean( true );
    
    console.log(s.valueOf());//abc
    console.log(n.valueOf());//42
    console.log(b.valueOf());//true

    参考资料:

    https://blog.csdn.net/baibaider/article/details/80660993

  • 相关阅读:
    html input在标签内设置禁止输入空格
    JS判断json是否为空
    python常见问题集锦
    Node.js入门教程合集
    Vue入门教程合集
    将博客搬至CSDN
    Python 使用PyInstaller打包发布
    VSCode开发Python
    Python 验证码解析
    IntelliJ IDEA常见问题及使用技巧(持续更新)
  • 原文地址:https://www.cnblogs.com/fmyao/p/12555012.html
Copyright © 2011-2022 走看看