首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无限原型链

无限原型链
EN

Stack Overflow用户
提问于 2013-10-31 20:31:23
回答 1查看 508关注 0票数 2

有人能告诉我为什么在这段代码中:

代码语言:javascript
复制
var originalfunc = function() {
    this.run(this)
};

originalfunc.prototype.run = function(basefunc) {
    this.basefunc = basefunc;
    console.log(this);
};

var r = new originalfunc();

生成一个看起来是无限的原型链:

为什么会发生这种情况?我知道我将原始函数obj指定为运行原型的属性,但我只做过一次。

在这里工作小提琴:

http://jsfiddle.net/YmThL/

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-10-31 20:33:07

this.basefunc设置为对this引用的对象的引用。

构造函数调用"run",将值this传递给它。在这一点上,this指的是正在构建的新对象。"run“函数在同一个对象上设置"basefunc”属性(因为this也会在该调用中引用它以"run")到参数,该参数就是该对象。

其效果与构造函数简单地做了相同的事情:

代码语言:javascript
复制
this.basefunc = this;
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19716099

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档