【问题标题】:Should this be stored in a variable when referencing to an objects methods? (JavaScript)引用对象方法时是否应将其存储在变量中? (JavaScript)
【发布时间】:2012-05-26 23:50:42
【问题描述】:

我使用 this 多次引用 JavaScript 对象的地方

var myObj = {
   method1 : function() {},
   method2 : function() {},
   method3 : function {},
   init : function() {
       this.method1();
       this.method2(); 
       this.method3();  
   }
};

是否有任何性能提升,我应该将this 存储在变量中吗?喜欢:

init : function() {
    var self = this;

    self.method1();
    self.method2(); 
    self.method3();  
}

【问题讨论】:

  • 你明显误解了self的用法。
  • +1 表示写得很好的问题。

标签: javascript oop variables this


【解决方案1】:

无需将this 引用存储在变量中,除非您需要将该上下文传递到闭包中。

这是一个示例,说明您何时可能需要将 this 指针传递到闭包中,例如需要引用 this 指针在外部父级中指向的任何元素的单击事件事件背景:

init : function() {

    $('.someElem').click( 
        (function(self) {
            return function() {
                self.method1();
                self.method2(); 
                self.method3();  
            }
        })(this)   // pass "this" into the "self" parameter as an argument
    );

}

在您的情况下,您不必要地创建了一个局部变量并在您确实不需要时为其分配了一些东西。它是多余的,并且还会创建一个不需要的变量。

【讨论】:

  • 感谢您的回答!如果我多次调用对象的属性,同样适用吗?例如:“this.property1.something”被多次调用,还是应该将它们存储在变量中?
  • this.property1.something 可以受益于分配给局部变量 IF, .something 是从 dom 以昂贵的方式计算的。此外,如果您将执行一系列操作并且只需要“保留”结果(同样,很可能与 dom 相关。)
  • @Andrew - 这是一个非常好的观点!感谢您指出这一点。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2012-09-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多