ES6箭頭函數及this指向詳解

WBOY
發布: 2022-08-08 10:43:02
轉載
1583 人瀏覽過

這篇文章為大家帶來了關於javascript的相關知識,其中主要介紹了箭頭函數以及this指向的相關問題,普通函數中的this表示調用此函數時的對象。而箭頭函數是沒有自己的this的,箭頭函數裡面的this會繼承自外部的this,下面一起來看一下,希望對大家有幫助。

ES6箭頭函數及this指向詳解

【相關推薦:javascript影片教學web前端

1.箭頭函數

用箭頭=> 定義函數

 var fn = function(num){
    return num;}var fn1 = (num)=>num;var fn3 = ()=>1;var  fn4 = (num1,num2,num3)=>num
登入後複製

如果箭頭函數的程式碼區塊部分有多條語句,就要使用大括號將它們括起來,並且使用return 返回。

        var func = (a,b)=>{
            return a+b;
        }
登入後複製

由於花括號{} 被解釋為程式碼區塊,所以如果箭頭函數直接傳回一個對象,必須在對像外加上上花括號,否則會報錯。

var func = (a,b)=>{name:a,age:b} //报错var func4 = (a,b)=>{
    return {
      name: a,
      age :b   } } // 不报错
登入後複製

箭頭函數還有一個更主要的功能: 解決this的指向問題。

2.this指向

先說一下普通函數中的this,普通函數中的this表示呼叫此函數時的物件。而箭頭函數是沒有自己的this的,箭頭函數裡面的this會繼承自外部的this。或是用程式碼

塊的概念解釋會比較直覺:箭頭函數中的this就是外層程式碼區塊的this。舉一個例子:

ES6箭頭函數及this指向詳解

ES6箭頭函數及this指向詳解

箭頭函數是ES6中的新增特性,他沒有自己的this,其this指向從外層程式碼庫繼承。

使用箭頭函數時要注意幾點:

  • #箭頭函數不能用作建構函數,用的話會拋出一個錯誤
  • 無法使用arguments參數,如果要用的話就用rest
  • 無法使用yield命令,所以箭頭函數無法用作Generator函數
  • 因為沒有自己的this,所以沒法透過bind、call、apply來改變this指向
  • 但是這不代表箭頭函數的this指向是靜態的,我們可以透過改變它外層程式碼庫的this指向來控制
  • 箭頭函數的this從外層程式碼庫繼承,所以箭頭函數的this是在定義的時候就綁定好了的,而普通函數是在呼叫的時候確定this指向
  • 字面量物件中直接定義的箭頭函數的this不綁定該對象,而是往外找一層,最簡單的情況是綁定到window

PS: 實際開發環境中,React可以使用箭頭函數解決一個經典問題,這裡不細說了。

給一個例子看箭頭函數的實際情況:

const obj = {
  fun1: function () {
    console.log(this);
    return () => {
      console.log(this);
    }
  },
  fun2: function () {
    return function () {
      console.log(this);
      return () => {
        console.log(this);
      }
    }
  },
  fun3: () => {
    console.log(this);
  }
}

let f1 = obj.fun1(); // obj
f1() // obj

let f2 = obj.fun2();
let f2_2 = f2(); // window
f2_2() // window

obj.fun3(); // window
登入後複製

針對每行輸出的分析:

let f1 = obj.fun1() // obj
登入後複製

這裡明顯進行的是隱式綁定,fun1的this指向obj

f1() // obj
登入後複製

這裡執行了上一行返回出來的箭頭函數,我們分析上一層程式碼庫的this指向obj,所以直接繼承,箭頭函數this指向

objlet f2 =obj.fun2()
登入後複製

fun2第一層執行的時候沒有列印程式碼,而是返回了一個函數出來,賦值給f2,並且這裡發生了綁定丟失,this指向由原來的obj指向了window(發生了賦值)

let f2_2 = f2() // window
登入後複製

f2()執行了,印出了改綁的this——window,然後將箭頭函數回傳出來,賦值給f2_2f

2_2() // window
登入後複製

執行列印出window,剛才的外層程式碼的this不是指向了window嗎,所以這裡就繼承了window作為this

obj.fun3() // window
登入後複製

在字面量中直接定義的箭頭函數無法繼承該物件的this,而是往外再找一層,就找到了window,因為字面量物件無法形成自己的一層作用域,但是建構子可以哦。

那我們怎麼操縱箭頭函數的this指向呢:

答案是修改外層程式碼庫的this指向,在箭頭函數定義之前就給this修改方向即可。

在上述程式碼的基礎上:

let fun4 = f2.bind(obj)() // obj
fun4() // obj
登入後複製

我們發現修改的是第二層方法的this指向,箭頭函數也繼承了下來。

  fun2: function () {
    return function () { // 我们修改的是这里的this
      console.log(this);
      return () => { // 然后这里定义的时候就继承啦
        console.log(this);
      }
    }
  },
登入後複製

【相關推薦:javascript影片教學web前端

以上是ES6箭頭函數及this指向詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
es6
來源:csdn.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板