var scope = this;
toolbar.add({
iconCls : 'graphOrderAdd',
name : 'graphOrder_btn',
handler : function(btn) {
scope.opToolbarClick(btn)
}
});
写ext代码的时候经常这样写scope.opToolbarClick(btn) 为什么不能写this呢
下面贴一段网络上的
JavaScript 中的 this 一直是容易让人误用的,尤其对于熟悉 Java 的程序员来说,因为 JavaScript 中的 this 与 Java 中的 this 有很大不同。在一个 function 的执行过程中,如果变量的前面加上了 this 作为前缀的话,如this.myVal
,对此变量的求值就从 this 所表示的对象开始。
this 的值取决于 function 被调用的方式,一共有四种,具体如下:
- 如果一个 function 是一个对象的属性,该 funtion 被调用的时候,this 的值是这个对象。如果 function 调用的表达式包含句点(.)或是 [],this 的值是句点(.)或是 [] 之前的对象。如
myObj.func
和myObj["func"]
中,func
被调用时的 this 是myObj
。 - 如果一个 function 不是作为一个对象的属性,那么该 function 被调用的时候,this 的值是全局对象(注:window)。当一个 function 中包含内部 function 的时候,如果不理解 this 的正确含义,很容易造成错误。这是由于内部 function 的 this 值与它外部的 function 的 this 值是不一样的。代码清单 5中,在
myObj
的func
中有个内部名为inner
的 function,在inner
被调用的时候,this 的值是全局对象,因此找不到名为myVal
的变量。这个时候通常的解决办法是将外部 function 的 this 值保存在一个变量中(此处为self
),在内部 function 中使用它来查找变量。 - 如果在一个 function 之前使用 new 的话,会创建一个新的对象,该 funtion 也会被调用,而 this 的值是新创建的那个对象。如
function User(name) {this.name = name}; var user1 = new User("Alex");
中,通过调用new User("Alex")
,会创建一个新的对象,以user1
来引用,User
这个 function 也会被调用,会在user1
这个对象中设置名为name
的属性,其值是Alex
。 - 可以通过 function 的 apply 和 call 方法来指定它被调用的时候的 this 的值。 apply 和 call 的第一个参数都是要指定的 this 的值,两者不同的是调用的实际参数在 apply 中是以数组的形式作为第二个参数传入的,而 call 中除了第一个参数之外的其它参数都是调用的实际参数。如
func.apply(anotherObj, [arg1, arg2])
中,func
调用时候的 this 指的是anotherObj
,两个参数分别是arg1
和arg2
。同样的功能用 call 来写则是func.call(anotherObj, arg1, arg2)
。
===================================================================
那么我上面的那段代码里面的this是什么呢 是window吗 我加上了代码做试验
var scope = this;
toolbar.add({
iconCls : 'graphAdd',
id:'aaa',
name : 'graphBtn',
handler : function(btn) {
alert(this==window); //false
alert(this==scope); //false
alert(this.id); //'aaa'
scope.opToolbarClick(btn);
}
});
那么很明显 handler函数是某个对象的属性 所以他的代码内部this指向的是这个‘某个对象’就是上面handler函数外层的那个{}定义的对象
另一段测试代码
function Container(param) {
var that = this;
function service() {
return this==window;
};
alert(service()); //true这个函数不是对象的成员 this指向全局
this.foo1=function(){
return this==window;
};
}
var a=new Container('aaaa');
alert(a.foo1()); //false foo1函数是对象的成员 this 不是window
我想的可能有不对的地方 望大家不吝赐教