search

Home  >  Q&A  >  body text

javascript - 为什么在构造函数的prototype中添加的属性不能被构造函数使用?

代码如下:

javascriptfunction Foo() {};
Foo.prototype.talk = function () {
    alert('hello~\n');
};

var a = new Foo;
a.talk(); // 输出'hello~\n'

但是如果这样:

javascriptFoo.talk() // 报错:Object doesn't support property or method 'talk'
Foo.prototype.talk() // 没有问题

而且当我使用

javascript"talk" in FOO  //返回false

但是如果查看

javascriptFoo.prototype

会发现talk属性的确已经被添加上去了。

非常不理解这种行为。

PHPzPHPz2902 days ago572

reply all(2)I'll reply

  • 巴扎黑

    巴扎黑2017-04-10 15:03:15

    因为这里a是构造出来的对象,其[[proto]]属性指向Foo.prototype。但Foo不是,Foo是一个函数对象,它的[[proto]]指向的是Function.prototype,因此有的是Foo.call Foo.apply这些函数对象上的方法(来自Function.prototypr)而不会有你定义的那个talk

    粗(错)暴(误)地说,一个是对象,另一个是类,类上的动态方法只能用对象才能调到,直接对着类调到的只能是静态方法

    reply
    0
  • PHPz

    PHPz2017-04-10 15:03:15

    protorype 是 构造函数的一个属性,我们可以这样理解。
    假设定义一个对象. var obj = {name:"Andy", alias:{nickname: "Tiger"}};
    我们要访问nickname这个obj的属性上的属性,需要这样访问: obj.alias.nickname;
    但是如果我们直接防范obj.nickname 就会返回undefined//如果是一个方法,调用nickname就会报错。

    reply
    0
  • Cancelreply