在某些jQuery代码中,我经常看到this被分配给jQuery中的变量,而我不理解这种方法的原因?
--这是一个jQuery插件构造函数的示例:
//constructor
function Nullpoll(element, options){
var widget = this;
widget.config = $.extend({}, defaults, options);
widget.element = element;
widget.element.on( "click", function() {
alert("Test")
});
widget.element.one("change", function(e){
widget.element.find("button").removeProp("disabled");
});
this.init();
}发布于 2014-10-28 10:07:48
this的值取决于它在其中显示的函数是如何调用的。
您可以将它赋值给另一个变量:
在这种情况下,传递给widget.element.one()的匿名函数使用调用Nullpoll时的this值。如果它尝试使用this关键字,它将得到一个不同的值(该值将取决于one函数如何调用匿名函数)
发布于 2014-10-28 10:06:39
http://learn.jquery.com/javascript-101/this-keyword/
在JavaScript中,就像在大多数面向对象的编程语言中一样,this是一个特殊的关键字,用于在方法中引用调用方法的对象。它的值是通过一系列简单的步骤确定的:
Function.call()或Function.apply()调用函数,则将this设置为传递给.call()/.apply()的第一个参数。如果传递给.call()/.apply()的第一个参数是null或undefined,this将引用全局对象(这是web浏览器中的window对象)。Function.bind()创建的,则this将是在创建该函数时传递给.bind()的第一个参数。this将引用该对象。this将引用全局对象。发布于 2014-10-28 10:08:05
当在您的作用域内使用内联回调时(例如示例中的事件处理程序),回调中的this值通常与父作用域不相同。因此,如果您希望从这些回调中访问父作用域中的this值,那么将其保存到父作用域中的局部变量是一种常见的设计模式。然后,在回调中,您仍然可以从父作用域引用该值,即使this在回调中可能有不同的值。
另一个好处是,一些最小化器可以使用局部变量而不是this来生成更小的代码,因为可以通过最小化器将局部变量重命名为单个字符变量,但不能将this重命名。
类似的问题,这里有很多答案:What is the value of var me = this;
https://stackoverflow.com/questions/26605468
复制相似问题