JavaScript构造函数例题:考察new的作用

JavaScript构造函数例题:考察new的作用

  1. 先看代码示例

    1. function Foo() {
              console.log(1)
              Foo.a = function () {
                  console.log(2)
              }
              this.a = function () {
                  console.log(3)
              }
              //改造一下
                  // return {
                  //     a(){
                  //         console.log(6);
                  //     }
                  // }
          }
          Foo.prototype.a = function () {
              console.log(4)
          }
          Foo.a = function () {
              console.log(5)
          }
          Foo.a();//5
          let obj = new Foo();//1
          obj.a();//3
          Foo.a();//2
      
    2. 结果
      1. 正确答案:5 1 3 2
      2. 我的第一反应答案是:5 3 2,忘记了1的打印。
      3. 小伙伴们:你们猜一下改造后的答案是什么呢 😄 ?
    3. 导致错误的原因
      1. 没有深刻理解 构造函数 new 的作用
  2. 构造函数中new的作用

    (1)在内存中创建一个新对象。

    (2)这个新对象内部的[[Prototype]]特性被赋值为构造函数的prototype属性。

    (3)构造函数内部的this被赋值为这个新对象(即this指向新对象)。

    (4)执行构造函数内部的代码(给新对象添加属性)。

    (5)如果构造函数返回非空对象,则返回该对象;否则,返回刚创建的新对象。

  3. 感悟

    1. 基础知识还是理解的不深刻
    2. 抓紧搬出来红宝书犀牛书 再撸 一遍基础
    3. 基础不牢,地动山摇。

生于忧患,死于安乐。 作者:孟子

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值