JavaScript 中this指向問題案例詳解
總結
- 全局環境 ➡️ window
- 普通函數 ➡️ window 或 undefined
- 構造函數 ➡️ 構造出來的實例
- 箭頭函數 ➡️ 定義時外層作用域中的 this
- 對象的方法 ➡️ 該對象
- call()、apply()、bind() ➡️ 第一個參數
全局環境
無論是否在嚴格模式下,this 均指向 window 對象。
console.log(this === window) // true
// 嚴格模式 'use strict' console.log(this === window) // true
普通函數
- 正常模式
- this 指向 window 對象
function test() { return this === window } console.log(test()) // true
- 嚴格模式
- this 值為 undefined
// 嚴格模式 'use strict' function test() { return this === undefined } console.log(test()) // true
構造函數
函數作為構造函數使用時,this 指向構造出來的實例。
function Test() { this.number = 1 } let test1 = new Test() console.log(test1.number) // 1
箭頭函數
函數為箭頭函數時,this 指向函數定義時上一層作用域中的 this 值。
let test = () => { return this === window } console.log(test()) // true
let obj = { number: 1 } function foo() { return () => { return this.number } } let test = foo.call(obj) console.log(test()) // 1
對象的方法
函數作為對象的方法使用時,this 指向該對象。
let obj = { number: 1, getNumber() { return this.number } } console.log(obj.getNumber()) // 1
call()、apply()、bind()
- 調用函數的 call()、apply() 方法時,該函數的 this 均指向傳入的第一個參數。
- 調用函數的 bind() 方法時,返回的新函數的 this 指向傳入的第一個參數。
let obj = { number: 1 } function test(num) { return this.number + num } console.log(test.call(obj, 1)) // 2 console.log(test.apply(obj, [2])) // 3 let foo = test.bind(obj, 3) console.log(foo()) // 4
到此這篇關於JavaScript 中this指向問題案例詳解的文章就介紹到這瞭,更多相關JavaScript 中this指向問題內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 一文搞懂JavaScript中的this綁定規則
- Vue自定義指令中無法獲取this的問題及解決
- javascript之函數進階詳解
- JavaScript中的this例題實戰總結詳析
- JavaScript深入刨析this的指向以及如何修改指向