JavaScript 中的 this 关键字是该语言中最强大但经常被误解的方面之一。它的值取决于函数的调用方式而不是函数的定义位置,这使得它对于管理代码中的上下文至关重要。
在本指南中,我们将通过实际示例探讨其细微差别,并深入探讨如何使用调用、应用和绑定来显式控制它。
在 JavaScript 中,this 指的是当前正在执行代码的对象。确定其值的规则取决于函数的调用类型:
当函数作为对象的方法调用时,this 指的是点之前的对象。
const car = { model: "Tesla", displayModel: function () { console.log(this.model); } }; car.displayModel(); // Output: "Tesla"
在此示例中,this.model 指向 car 对象的 model 属性,因为 car 是调用者。
当你需要精确控制this的值时,可以使用call、apply或bind。
call 方法立即使用指定的 this 值和单独的参数调用函数。
function greet(greeting, punctuation) { console.log(`${greeting}, ${this.name}${punctuation}`); } const person = { name: "Jack" }; greet.call(person, "Hello", "!"); // Output: "Hello, Jack!"
这里,调用确保 this.name 引用 person 对象的 name 属性。
apply 方法与 call 类似,但将参数作为数组而不是单独接收。
greet.apply(person, ["Hi", "."]); // Output: "Hi, Jack."
当您要传递一组参数时,这使得 apply 特别有用。
bind 方法返回一个新函数,并将 this 永久设置为指定对象,从而允许延迟调用。
const boundGreet = greet.bind(person, "Welcome"); boundGreet("?"); // Output: "Welcome, Jack?"
通过绑定,您可以创建一个与特定上下文绑定的可重用函数。
当使用 new 关键字调用函数时,this 指的是正在创建的新对象。
function Person(name) { this.name = name; } const jack = new Person("Jack"); console.log(jack.name); // Output: "Jack"
new 运算符将其设置为新创建的对象,允许您定义可重用的对象蓝图。
如果以上规则都不适用,则默认为全局对象。但是,在严格模式(“使用严格”)下,在这种情况下这是未定义的。
const car = { model: "Tesla", displayModel: function () { console.log(this.model); } }; car.displayModel(); // Output: "Tesla"
谨慎对待全局绑定,因为它可能会导致意外行为。
这是一个快速比较:
Method | Purpose | Execution | Argument Passing |
---|---|---|---|
call | Immediate invocation | Yes | Individually |
apply | Immediate invocation | Yes | Array of arguments |
bind | Delayed invocation (returns new function) | No | Individually or partially |
掌握 this 关键字对于编写干净的、上下文感知的 JavaScript 代码至关重要。通过了解隐式、显式、新的和全局绑定,您可以自信地跨各种场景进行管理。调用、应用和绑定等工具提供精细控制,使您的函数灵活且可重用。
关注我:Github Linkedin
以上是了解 JavaScript 中的'this”关键字:完整指南的详细内容。更多信息请关注PHP中文网其他相关文章!