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

手機站
千鋒教育

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

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

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

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

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

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

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

什么是箭頭函數

  一個基本的箭頭函數的形式為:

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

   其中:

  - `param1, param2, …, paramN` 是函數的參數。

  - `statements` 是函數的執行代碼塊。

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

  例如:

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` 是一個傳統函數,它的作用域是 `obj`,所以在打印時輸出了正確的結果。而`obj.sayHiArrow` 是一個箭頭函數,它的作用域是定義它的作用域,即全局作用域。所以在打印時,`this.name` 取不到值,輸出了 undefined。

  需要注意的是,當箭頭函數作為對象方法時,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.

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

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師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
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
日韩欧美国产另类 | 一本久久a久久精品vr综合 | 亚洲AV第一成肉网在线观看 | 日本女子下部视频午夜 | 日本乱亲倫频視 | 中文字幕在线不卡精品视频99 |