国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 什么是箭頭函數(shù)?箭頭函數(shù)中this關鍵字的用法

什么是箭頭函數(shù)?箭頭函數(shù)中this關鍵字的用法

來源:千鋒教育
發(fā)布人:syq
時間: 2023-05-26 17:25:00 1685093100

  箭頭函數(shù)是 ES6 中新增的一種函數(shù)寫法,它的語法比傳統(tǒng)的函數(shù)更簡潔,主要使用箭頭(=>)來定義函數(shù)。

什么是箭頭函數(shù)

  一個基本的箭頭函數(shù)的形式為:

(param1, param2, …, paramN) => { statements; }

   其中:

  - `param1, param2, …, paramN` 是函數(shù)的參數(shù)。

  - `statements` 是函數(shù)的執(zhí)行代碼塊。

  與傳統(tǒng)函數(shù)不同的是,箭頭函數(shù)沒有自己的this關鍵字,它繼承了父級作用域的this值。這意味著,在箭頭函數(shù)中使用this關鍵字,它的作用域是外層的函數(shù)作用域,而不是箭頭函數(shù)自身的作用域。

  例如:

let obj = {
name: 'Jack',
sayHi: function() {
console.log(`Hi, my name is ${this.name}.`);
},
sayHiArrow: () => {
console.log(`Hi, my name is ${this.name}.`);
}
}

obj.sayHi(); // 輸出:Hi, my name is Jack.
obj.sayHiArrow(); // 輸出:Hi, my name is undefined.

   在上面的例子中,`obj.sayHi` 是一個傳統(tǒng)函數(shù),它的作用域是 `obj`,所以在打印時輸出了正確的結果。而`obj.sayHiArrow` 是一個箭頭函數(shù),它的作用域是定義它的作用域,即全局作用域。所以在打印時,`this.name` 取不到值,輸出了 undefined。

  需要注意的是,當箭頭函數(shù)作為對象方法時,this指向仍可被修改。例如:

let obj = {
name: 'Jack',
sayHiArrow: () => {
console.log(`Hi, my name is ${this.name}.`);
},
sayHi: function() {
console.log(`Hi, my name is ${this.name}.`);
},
sayHiWithCall: function() {
console.log(`Hi, my name is ${this.name}.`);
}
}

obj.sayHiArrow(); // 輸出:Hi, my name is undefined.
obj.sayHi(); // 輸出:Hi, my name is Jack.
obj.sayHiWithCall.call({name: 'Tom'}); // 輸出:Hi, my name is Tom.

   在上述例子中,我們可以通過將傳統(tǒng)函數(shù)`sayHi`的普通調用方式修改為使用 `call` 方法傳入一個新的上下文來改變this指向,而對于箭頭函數(shù)`sayHiArrow`,無論如何都指向全局作用域。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業(yè)內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT