JavaScript Object 对象 再解(一)

2021-05-12 08:27

阅读:654

  • 事实上,JavaScript 的’类’仅仅是运行时对象的一个私有属性,而 JavaScript 中是无 法自定义类型的。

    3 与 new Number(3) 是完全不同的

    3
    ‘3‘
    new Number(3)
    
    s
    ‘s‘
    new String(s)
    
    true
    false
    new Boolean(true)
    new Boolean(false)
    

    Number、String 和 Boolean,三个构造器是两用的,当跟 new 搭配时,它们产生对 象,当直接调用时,它们表示强制类型转换。

    Symbol 函数比较特殊,直接用 new 调用它会抛出错误,但它仍然是 Symbol 对象的构 造器。

    JavaScript 语言设计上试图模糊对象和基本类型之间的关系, 我们日常代码可以把对象的 方法在基本类型上使用,比如:

    console.log(‘hello‘.charAt(3))
    console.log(‘hello‘.charCodeAt(3))
    String.fromCharCodeAt(‘hello‘.charCodeAt(3))
    

    甚至我们在原型上添加方法,都可以应用于基本类型,比如以下代码,在 Symbol 原型上 添加了 hello 方法,在任何 Symbol 类型变量都可以调用。

    Symbol.prototype.hello = () => console.log("hello")
    var a = Symbol("a")
    console.log(typeof a)
    a.hello()
    

    然后,有个问题,问题是:为什么给对象添加的方法能用在基本类型上?

    答案就是: . 运算符的功劳。 该运算符提供了装箱操作,它会根据我们使用的基本类型构造一个临时的对象,使得我们能够在基础类型上调用该对应对象的方法。


  • 评论


    亲,登录后才可以留言!