在 jQuery 中,$(this)
和 this
关键字都可以用来引用当前元素,但它们的使用场景和上下文有所不同。
this
: 在普通的 JavaScript 函数中,this
关键字是没有定义的。在 jQuery 中,如果你在一个函数内部使用this
,它实际上会引用到全局对象(在浏览器中通常是window
对象)。因此,如果你在 jQuery 代码中直接使用this
,它通常不会按照你预期的方式工作。$(this)
: 在 jQuery 事件处理函数中,$(this)
可以用来引用触发事件的元素。例如,当一个点击事件发生时,$(this)
将引用被点击的元素。这是因为this
在事件处理函数中默认指向触发事件的元素。通过将this
包装在$()
中,你可以将其转换为一个 jQuery 对象,从而可以使用 jQuery 的方法。
下面是一个简单的示例来说明这两者的区别:
// 使用 this function myFunction() { console.log(this); // 输出全局对象(在浏览器中是 window 对象) } // 使用 $(this) $("#myButton").click(function() { console.log($(this)); // 输出被点击的按钮的 jQuery 对象 });
在这个例子中,如果你点击 ID 为 "myButton" 的按钮,第二个示例中的 console.log($(this))
将输出被点击的按钮的 jQuery 对象,而不是全局对象。