$(this) 和 this 关键字在 jQuery 的不同

在 jQuery 中,$(this) 和 this 关键字都可以用来引用当前元素,但它们的使用场景和上下文有所不同。

  1. this: 在普通的 JavaScript 函数中,this 关键字是没有定义的。在 jQuery 中,如果你在一个函数内部使用 this,它实际上会引用到全局对象(在浏览器中通常是 window 对象)。因此,如果你在 jQuery 代码中直接使用 this,它通常不会按照你预期的方式工作。
  2. $(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 对象,而不是全局对象。

你可能感兴趣的:(jquery,前端,javascript)