首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在PrototypeJS类访问类的类方法中赋予类成员一个函数

在PrototypeJS类访问类的类方法中赋予类成员一个函数
EN

Stack Overflow用户
提问于 2009-07-07 20:48:38
回答 3查看 366关注 0票数 2

假设我有一个非常简单的PrototypeJS类,如下所示:

代码语言:javascript
运行
复制
var Foo = Class.create({
  initialize:  function() {
    this.bar = 'bar';
  },

  dostuff:  function() {
    $$('.enabled').each( function(elem) {
      alert(this.bar);  //FAIL
    });
  }
});

这会失败,因为传递给.each()的函数不知道这是指什么。

如何从函数内部访问类的bar属性?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-07-07 22:53:14

您可以使用原型绑定函数,它“将函数的执行范围锁定为对象”。

代码语言:javascript
运行
复制
var Foo = Class.create({
  initialize:  function() {
    this.bar = 'bar';
  },

  dostuff:  function() {
    $$('.enabled').each( function(elem) {
      alert(this.bar);
    }.bind(this)); // Set the execution scope to Foo
  }
});
票数 1
EN

Stack Overflow用户

发布于 2009-07-07 20:55:32

尝试:

代码语言:javascript
运行
复制
dostuff:  function() {
   var that = this;

   $$('.enabled').each( function(elem) {
        alert(that.bar);  //FTW
   });
}

或者,将上下文传递给each()

代码语言:javascript
运行
复制
dostuff:  function() {
   $$('.enabled').each( function(elem) {
        alert(this.bar);  //FTW
   }, this); // Context
}
票数 2
EN

Stack Overflow用户

发布于 2009-07-07 20:55:46

嗯,我不是原型专家,但我认为这可能有助于回答你的问题-- http://www.duncangunn.me.uk/dasblog/2009/05/26/ObjectorientedEventHandlingInJavascript.aspx

如果这样做了,如果没有,请告诉我,为浪费你的时间道歉!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1094782

复制
相关文章

相似问题

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