JavaScript 異步編程與請求取消全指南


JavaScript 異步編程與請求取消全指南

涵蓋:同步/異步、Promise、async/await、AbortController、前后端協作


一、同步與異步

1. 同步(Synchronous)

  • 定義:代碼按順序執行,前一步完成才能執行下一步。
  • 特點:阻塞主線程,適合簡單邏輯。
  • 示例
    console.log("步驟1");  
    console.log("步驟2"); // 必須等待步驟1完成
    

2. 異步(Asynchronous)

  • 定義:代碼非阻塞執行,任務完成后通過回調、Promise 或事件通知結果。
  • 特點:高效但復雜度高,適合網絡請求、I/O 操作。
  • 示例
    setTimeout(() => console.log("異步任務"), 1000);  
    console.log("繼續執行"); // 立即執行
    

二、Promise 核心知識

1. 基本概念

  • 狀態Pending(進行中)、Fulfilled(成功)、Rejected(失敗)。
  • 創建與使用
    const promise = new Promise((resolve, reject) => {setTimeout(() => resolve("成功"), 1000);
    });
    promise.then(result => console.log(result));  
    

2. 鏈式調用與靜態方法

  • 鏈式調用
    fetch(url).then(response => response.json()).catch(error => console.error(error));
    
  • 靜態方法
    • Promise.all():所有成功返回結果數組。
    • Promise.race():返回第一個完成的結果。

三、async/await 進階

1. 基本用法

  • async 函數:隱式返回 Promise。
  • await:等待 Promise 完成并提取結果。
    async function fetchData() {const data = await fetch(url);return data.json();
    }
    

2. 錯誤處理

  • try...catch:捕獲異步錯誤。
    async function safeFetch() {try {const data = await fetch(url);} catch (error) {console.error("請求失敗:", error);}
    }
    

3. 并發控制

  • 串行
    await task1();  
    await task2(); // 等待 task1 完成
    
  • 并行
    const [res1, res2] = await Promise.all([task1(), task2()]);
    

四、請求取消:AbortController

1. 核心功能

  • 中斷異步操作(如 fetch 請求)。
  • 核心對象
    • AbortController:生成中斷信號。
    • AbortSignal:傳遞給異步任務。

2. 使用示例

const controller = new AbortController();// 發起請求并傳遞信號
fetch(url, { signal: controller.signal }).catch(error => {if (error.name === "AbortError") {console.log("請求已取消");}});// 用戶點擊取消按鈕
document.getElementById("cancel-btn").onclick = () => controller.abort();

3. 超時自動取消

async function fetchWithTimeout(url, timeoutMs) {const controller = new AbortController();const timeoutId = setTimeout(() => controller.abort(), timeoutMs);try {const response = await fetch(url, { signal: controller.signal });clearTimeout(timeoutId); // 請求成功時清除定時器return response.json();} catch (error) {if (error.name === "AbortError") {throw new Error(`超時(${timeoutMs}ms)`);}}
}

五、后端處理請求取消(Java/Spring Boot)

1. 默認行為

  • 客戶端斷開后,服務器繼續執行任務
  • 示例
    @GetMapping("/data")
    public String longTask() throws InterruptedException {Thread.sleep(5000); // 即使客戶端斷開仍會執行return "完成";
    }
    

2. 主動終止任務

  • 監聽連接中斷(使用 DeferredResult):
    @GetMapping("/async")
    public DeferredResult<String> asyncTask() {DeferredResult<String> deferredResult = new DeferredResult<>();Future<?> future = executor.submit(() -> {try {Thread.sleep(5000);deferredResult.setResult("完成");} catch (InterruptedException e) {deferredResult.setErrorResult("已取消");}});// 客戶端斷開時取消任務deferredResult.onCompletion(() -> future.cancel(true));return deferredResult;
    }
    

3. 數據庫查詢超時

@Query(value = "SELECT * FROM large_table", timeout = 5) // 5秒超時
List<Record> findLargeData();

六、關鍵問題解答

1. 客戶端取消請求后,后端是否繼續執行?

  • 默認繼續執行,需后端主動監聽連接中斷事件并終止任務。

2. 為什么需要 async 函數?

  • 語法要求await 必須在 async 函數內使用。
  • 隱式返回 Promise:方便異步操作的值傳遞。

3. 如何避免回調地獄?

  • 使用 Promise 鏈式調用async/await

七、最佳實踐

  1. 前端
    • 使用 AbortController 取消不再需要的請求。
    • 超時設置避免長時間等待。
  2. 后端
    • 監聽客戶端斷開事件,終止耗時操作。
    • 數據庫操作設置查詢超時。
  3. 通用
    • 關鍵業務設計冪等性邏輯(如支付去重)。

總結:異步編程需兼顧效率與資源管理,合理使用取消機制可顯著提升應用性能和用戶體驗。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/903100.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/903100.shtml
英文地址,請注明出處:http://en.pswp.cn/news/903100.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

永久緩存 Git 憑證

永久緩存 Git 憑證 打開終端或命令行工具。 執行以下命令&#xff0c;設置 Git 使用 store 憑證幫助程序&#xff1a; bash git config --global credential.helper store第一次執行 git pull 時輸入賬號密碼。之后&#xff0c;所有需要憑證的操作都將自動使用存儲的憑證&…

力扣-48.旋轉圖像

題目描述 給定一個 n n 的二維矩陣 matrix 表示一個圖像。請你將圖像順時針旋轉 90 度。 你必須在 原地 旋轉圖像&#xff0c;這意味著你需要直接修改輸入的二維矩陣。請不要 使用另一個矩陣來旋轉圖像。 class Solution { public:void rotate(vector<vector<int>…

Qt ModbusSlave多線程實踐總結

最近項目中用到了ModbusSlave&#xff0c;也就是Modbus從設備的功能&#xff0c;之前用的基本都是master設備&#xff0c;所以讀取數據啥的用單線程就行了&#xff0c;用 void WaitHelper::WaitImplByEventloop(int msec) {QEventLoop loop;QTimer::singleShot(msec, &loop…

opencv--圖像

像素(像素點) 定義&#xff1a; Pixel 是 Picture Element&#xff08;圖像元素&#xff09;的縮寫&#xff0c;是數字圖像中最小的獨立單位。每個像素代表圖像中的一個點的顏色和亮度信息。 關鍵特性&#xff1a; 顏色&#xff1a;通過不同的色彩模型&#xff08;如RGB、CMYK…

記錄學習匯編語言02+各種寄存器分類

8086cpu是十六位的 然后寄存器能存八位 所以分為高八位低八位 高八位在下面低八位在上面 從下往上讀&#xff08;從地址小的地方開始讀&#xff09; 8086cpu種有兩個和棧相關的寄存器 棧段寄存器ss&#xff08;棧頂的段寄存器&#xff09; 棧頂指針寄存器sp&#xff08;…

OpenCV 圖形API(53)顏色空間轉換-----將 RGB 圖像轉換為灰度圖像函數RGB2Gray()

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 將圖像從 RGB 色彩空間轉換為灰度。 R、G 和 B 通道值的常規范圍是 0 到 255。生成的灰度值計算方式如下&#xff1a; dst ( I ) 0.299 ? src…

(51單片機)LCD顯示數據存儲(DS1302時鐘模塊教學)(LCD1602教程)(獨立按鍵教程)(延時函數教程)(I2C總線認識)(AT24C02認識)

目錄 演示視頻&#xff1a; 源代碼 main.c LCD1602.c LCD1602.h AT24C02.c AT24C02.h Key.c Key.h I2C.c I2C.h Delay.c Delay.h 代碼解析與教程&#xff1a; Dealy模塊 LCD1602模塊 Key模塊 I2C總線模塊 AT24C02模塊 /E2PROM模塊 main模塊 演示視頻&#xff1a; E2…

電子病歷高質量語料庫構建方法與架構項目(數據遺忘篇)

引言 在人工智能與醫療健康的深度融合時代,醫療數據的價值與風險并存。跨機構和平臺的醫療數據共享對于推動醫學研究、提高診斷精度和實現個性化治療至關重要,但同時也帶來了前所未有的隱私挑戰。先進的AI技術可以從理論上去標識化的醫療掃描中重新識別個人身份,例如從MRI數…

CentOS創建swap內存

服務器版本為CentOS7 一、檢查現有 swap 空間 sudo swapon --show如果系統中沒有 swap 空間或者現有的 swap 空間不足&#xff0c;可以繼續后續步驟來創建 swap 空間。 二、創建 swap 文件&#xff08;推薦 2GB 作為示例&#xff09; sudo dd if/dev/zero of/swapfile bs1M …

在Android中如何使用Protobuf上傳協議

在 Android 中使用 Protobuf&#xff08;Protocol Buffers&#xff09;主要分為以下幾個步驟&#xff1a; ? 1. 添加 Protobuf 插件和依賴 在項目的 build.gradle&#xff08;Project 級&#xff09;文件中添加 Google 的 Maven 倉庫&#xff08;通常默認已有&#xff09;&am…

Android學習總結之ANR問題

一、ANR 基礎概念與核心原理&#xff08;必考題&#xff09; 1. 什么是 ANR&#xff1f;為什么會發生 ANR&#xff1f; 答案要點&#xff1a; 定義&#xff1a;ANR&#xff08;Application Not Responding&#xff09;即應用無響應&#xff0c;是 Android 系統檢測到主線程&…

視頻監控從安裝到優化的技術指南,視頻匯聚系統EasyCVR智能安防系統構建之道

在當今數字化安防時代&#xff0c;監控系統的安裝與配置對于保障各類場所的安全起著至關重要的作用。從前期規劃到實際安裝&#xff0c;再到后期的功能實現與維護&#xff0c;每一個環節都不容小覷。本文將詳細闡述監控安裝過程中的關鍵要點&#xff0c;并結合EasyCVR平臺功能&…

如何避免IDEA每次打開新項目都重復配置Maven?

每次打開新項目都要重新設置Maven路徑&#xff1f;每次導入工程都要手動調整settings.xml&#xff1f;如果你也受夠了IDEA這種“健忘”行為&#xff0c;那么這篇文章就是為你準備的&#xff01;今天我們就來徹底解決這個問題&#xff0c;讓IDEA記住你的Maven配置&#xff0c;一…

PostgesSQL外部數據封裝FDW

PostgesSQL外部數據封裝FDW 1. FDW外部數據配置&#xff08;單表&#xff09;1.1 遠端數據庫創建測試表1.2 安裝擴展postges\_fdw1.3 創建外部服務SERVER1.4 創建用戶映射USER MAPPING1.5 創建遠程表FOREIGN TABLE1.6 數據庫更新測試 2. FDW外部數據配置&#xff08;用戶&#…

策略模式(Strategy Pattern)詳解

文章目錄 1. 什么是策略模式&#xff1f;2. 為什么需要策略模式&#xff1f;3. 策略模式的核心概念3.1 策略&#xff08;Strategy&#xff09;3.2 具體策略&#xff08;Concrete Strategy&#xff09;3.3 上下文&#xff08;Context&#xff09; 4. 策略模式的結構5. 策略模式的…

在 Vue3 中封裝的 Axios 實例中,若需要為部分接口提供手動取消請求的功能

核心思路 封裝接口時返回 Promise 和 abort 方法&#xff1a; 為需要支持取消的接口返回一個對象&#xff0c;包含 promise 和 abort 方法&#xff0c;用戶可通過 abort 主動中斷請求。使用 AbortController 或 CancelToken&#xff1a; 推薦 AbortController&#xff08;瀏覽…

Flink介紹——實時計算核心論文之Dataflow論文詳解

引入 在過去的幾篇文章里&#xff0c;我們看到了大數據的流式處理系統是如何一步一步進化的。從最早出現的S4&#xff0c;到能夠做到“至少一次”處理的Storm&#xff0c;最后是能夠做到“正好一次”數據處理的MillWheel。我們會發現&#xff0c;這些流式處理框架&#xff0c;…

Python自動化解決滑塊驗證碼的最佳實踐

1. 引言&#xff1a;滑塊驗證碼的挑戰與自動化需求 滑塊驗證碼&#xff08;Slider CAPTCHA&#xff09;是當前互聯網廣泛使用的反爬機制之一&#xff0c;它要求用戶手動拖動滑塊到指定位置以完成驗證。這種驗證方式可以有效阻止簡單的自動化腳本&#xff0c;但對爬蟲開發者來說…

路由與OSPF學習

【路由是跨網段通訊的必要條件】 路由指的是在網絡中&#xff0c;數據包從源主機傳輸到目的主機的路徑選擇過程。 路由通常涉及以下幾個關鍵元素&#xff1a; 1.路由器&#xff1a;是一種網絡設備&#xff0c;負責將數據包從一個網絡傳輸到另一個網絡。路由器根據路由表來決定…

(done) 吳恩達版提示詞工程 5. 推理 (情緒分類,控制輸出格式,輸出 JSON,集成多個任務,文本主題推斷和索引,主題內容提醒)

url: https://www.bilibili.com/video/BV1Z14y1Z7LJ?spm_id_from333.788.videopod.episodes&vd_source7a1a0bc74158c6993c7355c5490fc600&p2 別人的筆記 url: https://zhuanlan.zhihu.com/p/626966526 5. 推理任務&#xff08;Inferring&#xff09; 這個視頻是關于…