前端碎碎念 2019-07-25 12:23 采纳率: 100%
浏览 329
已采纳

以下代码段的执行结果求解释。

function Foo() {
    Foo.a = function() {
        console.log(1)
    }
    this.a = function() {
        console.log(2)
    }
}
Foo.prototype.a = function() {
    console.log(3)
}
Foo.a = function() {
    console.log(4)
}
Foo.a();
let obj = new Foo();
obj.a();
Foo.a();

这个代码执行结果是 4 2 1
obj.a()为什么输出2???

  • 写回答

2条回答 默认 最新

  • 前端碎碎念 2021-08-27 16:37
    关注

    自问自答一下
    Foo.a();
    这个输出4的原因是因为function Foo() 定义后并没有执行,等到调用才会去执行,所以内部并未执行
    所以Foo.a()会先从自身找属性,找到了console.log(4)这个方法

    let obj = new Foo();
    这里讲对象进行了实例化,Foo函数执行了一次,且内部的this指向实例本身

    obj.a();
    此时obj.a()同样是从obj这个对象属性上找,console.log(2)

    Foo.a();
    从对象Foo属性上找a方法,此时找到了console.log(1)

    为什么3这个没有执行呢,是因为对象静态属性上找到了该函数,要是找不到,那么就会到原型链上寻找,一直找到顶层Object()
    要想执行3,那么可以先把对象上的实例属性去删除,那么就会执行原型上的方法,输出3

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已采纳回答 8月27日

悬赏问题

  • ¥15 怎么把多于硬盘空间放到根目录下
  • ¥15 Matlab问题解答有两个问题
  • ¥50 Oracle Kubernetes服务器集群主节点无法访问,工作节点可以访问
  • ¥15 LCD12864中文显示
  • ¥15 在使用CH341SER.EXE时不小心把所有驱动文件删除了怎么解决
  • ¥15 gsoap生成onvif框架
  • ¥15 有关sql server business intellige安装,包括SSDT、SSMS。
  • ¥15 stm32的can接口不能收发数据
  • ¥15 目标检测算法移植到arm开发板
  • ¥15 利用JD51设计温度报警系统