JS中的箭頭函數

来源:https://www.cnblogs.com/ronaldo9ph/archive/2023/05/11/17390092.html
-Advertisement-
Play Games

在JavaScript中,箭頭函數是一種簡化的函數語法,它在ES6(ECMAScript 2015)引入。箭頭函數的語法比傳統的function表達式更簡潔,同時還有一些特性,例如繼承外部作用域的this值。 箭頭函數的基本語法如下: (param1, param2, ..., paramN) => ...


在JavaScript中,箭頭函數是一種簡化的函數語法,它在ES6(ECMAScript 2015)引入。箭頭函數的語法比傳統的function表達式更簡潔,同時還有一些特性,例如繼承外部作用域的this值。

箭頭函數的基本語法如下:

(param1, param2, ..., paramN) => { statements }
(param1, param2, ..., paramN) => expression

 

當箭頭函數只有一個參數時,可以省略括弧:

param => { statements }
param => expression

 

當函數體只包含一個返回值表達式時,可以省略花括弧並直接返回該表達式的值:

(param1, param2) => param1 + param2

 



需要註意的是,箭頭函數有以下特性:

1. 沒有自己的this值 :箭頭函數內的this值繼承自包含它的函數作用域,這有助於解決一些this指向問題。
2. 沒有arguments對象 :在箭頭函數內部,無法訪問傳統函數中的arguments對象。但你可以使用剩餘參數(...rest)語法來獲取參數列表。
3. 不能用作構造函數 :箭頭函數不能用作構造函數,因此不能使用new運算符實例化。
4. 沒有原型 :箭頭函數沒有prototype屬性,因為它們不能作為構造函數使用。

 


更多箭頭函數的用法

1. 鏈式調用:

箭頭函數的簡潔語法使得在鏈式調用中使用它們變得更加容易。例如,我們可以在數組上使用多個數組方法並將箭頭函數作為回調函數:

const numbers = [1, 2, 3, 4, 5];

const doubledAndFiltered = numbers
  .map(num => num   2)
  .filter(num => num > 5);

console.log(doubledAndFiltered); // [6, 8, 10]

 


2. 事件處理程式:

箭頭函數可以方便地用作事件處理程式,因為它們繼承了外部作用域的 this 值。這樣就避免了使用 bind 來綁定事件處理程式的需要。例如:

class Button {
  constructor() {
    this.buttonElement = document.createElement('button');
    this.buttonElement.textContent = 'Click me!';
    this.buttonElement.addEventListener('click', () => this.handleClick());
    document.body.appendChild(this.buttonElement);
  }

  handleClick() {
    console.log('Button clicked!');
  }
}

const button = new Button();

 


3. 在數組方法中使用:

常見的數組方法,如 filter 、 reduce 、 forEach 等,也可以與箭頭函數一起使用,以簡化代碼並使其更具可讀性:

const numbers = [1, 2, 3, 4, 5];

const evenNumbers = numbers.filter(num => num % 2 === 0);

console.log(evenNumbers); // [2, 4]

const sum = numbers.reduce((acc, num) => acc + num, 0);

console.log(sum); // 15

numbers.forEach((num, index) => console.log( Index ${index}: ${num} ));

 


4. 立即調用的箭頭函數:

箭頭函數還可以作為立即調用函數表達式(IIFE)使用,這在某些場景下有助於限制變數的作用域:

const result = (() => {
  const localVar = 'I am only available within this IIFE';
  return localVar.toUpperCase();
})();

console.log(result); // 'I AM ONLY AVAILABLE WITHIN THIS IIFE'

 


5. 對象字面量和箭頭函數:

在箭頭函數中直接返回對象字面量時,需要註意語法。由於大括弧 {} 在箭頭函數中被解釋為代碼塊,而不是對象字面量,因此需要在對象字面量周圍添加額外的括弧:

const getObject = () => ({ key: 'value' });

console.log(getObject()); // { key: 'value' }

 


6. 多行箭頭函數:

雖然箭頭函數通常用於簡潔的單行函數,但它們也可以用於多行函數。在這種情況下,需要使用大括弧包裹函數體,併在需要返回值時使用 return 關鍵字:

const addWithLogging = (a, b) => {
  console.log( Adding ${a} and ${b} );
  return a + b;
};

console.log(addWithLogging(3, 4)); // 輸出 "Adding 3 and 4",然後輸出 7

 


7. 箭頭函數與解構參數:

箭頭函數可以與解構參數一起使用,可以更簡潔地處理對象或數組。以下是一些示例:

// 對象解構
const users = [
  { id: 1, name: 'Alice', age: 30 },
  { id: 2, name: 'Bob', age: 25 },
  { id: 3, name: 'Charlie', age: 35 },
];

const getUserNames = users.map(({ name }) => name);
console.log(getUserNames); // 輸出:['Alice', 'Bob', 'Charlie']

// 數組解構
const points = [
  [1, 2],
  [3, 4],
  [5, 6],
];

const getDistancesFromOrigin = points.map(([x, y]) => Math.sqrt(x   x + y   y));
console.log(getDistancesFromOrigin); // 輸出:[2.23606797749979, 5, 7.810249675906654]

 


8. 箭頭函數和 this :

由於箭頭函數在其詞法作用域內捕獲 this 值,因此在某些情況下可能導致問題。例如,在對象方法中使用箭頭函數時,它不會獲取到對象的 this ,而是捕獲到外部作用域的 this 。為瞭解決這個問題,需要使用傳統的 function 聲明或表達式。

const obj = {
  value: 10,
  getValue: function() {
    // 正常的function表達式, this  指向obj
    return this.value;
  },
  getValueWithArrow: () => {
    // 箭頭函數, this  指向外部作用域(在這種情況下是全局對象或undefined)
    return this.value;
  },
};

console.log(obj.getValue()); // 輸出:10
console.log(obj.getValueWithArrow()); // 輸出:undefined(嚴格模式)或全局對象的value屬性

 


9. 箭頭函數作為高階函數的參數:

在處理高階函數時,箭頭函數非常有用,因為它們可以使代碼更簡潔。高階函數是接受一個或多個函數作為參數、返回一個函數的函數。這裡有一個使用箭頭函數的高階函數示例:

const add = a => b => a + b;

const add5 = add(5);
console.log(add5(3)); // 輸出:8

在上面的示例中, add 函數接受一個參數 a 並返回一個新的函數,該函數接受另一個參數 b 並返回 a + b 的結果。



10. 不要在所有場景中都使用箭頭函數:

儘管箭頭函數有很多優點,但並非所有場景都適用。以下是一些避免使用箭頭函數的情況:

- 在需要動態上下文的函數(如事件處理程式)中,箭頭函數繼承了它們的詞法作用域。在這種情況下,可能需要使用 function 聲明或表達式,以便根據需要訪問當前上下文。
- 當需要使用 arguments 對象時,箭頭函數不會創建它。在這種情況下,需要使用傳統的 function 聲明或表達式。



總之,箭頭函數的簡潔語法和特性使得它們在許多情況下都非常有用,還可以用在setTimeout、錯誤處理、Promise中等等。但是,在遇到 this 、 arguments 或其他相關問題時,有時可能需要使用傳統的 function 聲明或表達式來解決特定問題。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 源碼 https://github.com/webabcd/flutter_demo 作者 webabcd 一統天下 flutter - 插件: flutter 使用 web 原生控制項,並做數據通信 示例如下: lib\plugin\plugin2.dart /* * 插件 * 本例用於演示 flu ...
  • 一、本文想給你聊的東西包含一下幾個方面:(僅限於es6之前的語法哈,因為es6裡面class這關鍵字用上了。。) 1.原型是啥?原型鏈是啥? 2.繼承的通用概念。 3.Javascript實現繼承的方式有哪些? 二、原型是啥?原型鏈是啥? 1.原型是函數本身的prototype屬性。 首先js和ja ...
  • 背景: 本來項目開發系統防掛機功能,在其餘游覽器中均可以使用。但是呢在蘋果的safair游覽器中會出現幾率失效,最後經過排查發現是蘋果的墓碑機制導致。即:此標簽頁活躍,其他標簽頁假死。然後就導致防掛機失效了。 原理: 假如當前游覽器中有3個標簽頁分別是A,B,C,每個標簽頁都有倒計時。正常情況下,每 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 Vue3+TS(uniapp)手擼一個聊天頁面 前言 最近在自己的小程式中做了一個智能客服,API使用的是雲廠商的API,然後聊天頁面...嗯,找了一下關於UniApp(vite/ts)版本的好像不多,有一個官方的但其中的其他代碼太多了, ...
  • 本系列內容為JS全解析,為千鋒教育資深前端老師獨家創作 致力於為大家講解清晰JavaScript相關知識點,含有豐富的代碼案例及講解。如果感覺對大家有幫助的話,可以【點個關註】持續追更~ this指向(掌握) this 是一個關鍵字,是一個使用在作用域內的關鍵字 作用域分為全局作用域和局部作用域(私 ...
  • 1、深拷貝 1.1、概念 對象的深拷貝是指其屬性與其拷貝的源對象的屬性不共用相同的引用(指向相同的底層值)的副本。 因此,當你更改源或副本時,可以確保不會導致其他對象也發生更改;也就是說,你不會無意中對源或副本造成意料之外的更改。 在深拷貝中,源和副本是完全獨立的。深拷貝與其源對象不共用引用,所以對 ...
  • 作者:京東科技 牛志偉 近期對Webpack5構建性能進行了優化,構建耗時從150s到60s再到10s,下麵詳細講解下優化過程。 優化前現狀 1.歷史項目基於Vue3 + Webpack5技術棧,其中webpack配置項由開發者自己維護(沒有使用@vue/cli-service),並且做了環境分離。 ...
  • 效果如下 代碼實現 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>帖子類別</title> <meta name="renderer" content="webkit"> <meta http-equiv="X-UA-Comp ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...