簡介:
非同步程式設計是現代 JavaScript 開發的基石,使任務能夠並發執行而不會阻塞主執行緒。隨著時間的推移,JavaScript 已經發展出更優雅的解決方案來處理非同步操作。在本文中,我們將探討非同步 JavaScript 的演變,從傳統的回呼開始,逐步發展到 Promise 和 async/await 語法。
- 回呼函數: 傳統上,JavaScript 使用回呼函數來處理非同步操作。回調可讓您定義非同步任務完成後要執行的函數。然而,隨著程式碼庫變得越來越大、越來越複雜,基於回調的方法導致了諸如回調地獄和程式碼可讀性差等問題。
範例:
const datas =[ {name:"kishan",profession:"software Engineer"}, {name:"Anuj",profession:"software Engineer"} ] function getDatas(){ setTimeout(() => { datas.forEach((data,index)=>{ console.log(data.name); }) }, 1000); } function createddata(newdata,callback){ setTimeout(() => { datas.push(newdata) callback() }, 2000); }`` createddata({name:"jatin",profession:"software Engineer"},getDatas)
輸出:
運行程式碼時,輸出將是:
kishan Anuj jatin
步驟 2
Promise 比回呼更好地處理非同步操作,因為它們提供了一種更乾淨、更易於管理且防錯的非同步程式碼處理方式。這就是為什麼 Promise 被認為更好的原因:
- 避免回調地獄 回呼:嵌套多個回調會導致程式碼嵌套很深且難以閱讀(俗稱「回呼地獄」)。 Promise:Promise 鏈 .then() 調用,保持程式碼平坦且可讀
錯誤處理
回調:每個等級都必須明確處理錯誤,容易出錯。
承諾:使用 .catch(),您可以在一處處理錯誤更好的可讀性
Promise 使用 .then() 和 .catch() 具有清晰的結構,使程式碼更易於理解、調試和維護。連結多個非同步呼叫
Promise 讓連結順序非同步操作無縫
範例
const datas = [ { name: "kishan", profession: "software Engineer" }, { name: "Anuj", profession: "software Engineer" }, ]; function getDatas() { return new Promise((resolve) => { setTimeout(() => { datas.forEach((data) => { console.log(data.name); }); resolve(); // Signal completion }, 1000); }); } function createdData(newData) { return new Promise((resolve) => { setTimeout(() => { datas.push(newData); resolve(); // Signal completion }, 2000); }); } function logCompletion() { return new Promise((resolve) => { setTimeout(() => { console.log("All tasks completed!"); resolve(); }, 500); }); } // Usage with an Additional Task createdData({ name: "jatin", profession: "software Engineer" }) .then(getDatas) .then(logCompletion) // New Task .catch((err) => console.error(err));
工作原理:
建立資料:
2 秒後向 datas 陣列新增新的資料條目。
取得數據:
1 秒後記錄資料數組中的所有名稱。
logCompletion(新任務):
日誌「所有任務已完成!」500 毫秒後。
輸出:
當您執行更新的程式碼時,輸出將為:
kishan Anuj jatin All tasks completed!
為什麼 Promise 讓這一切變得如此簡單:
每個任務都會傳回一個 Promise,讓您能夠輕鬆新增、重新排列或刪除鏈中的步驟。
簡潔的結構確保順序得以維持且易於遵循。
步驟 3
使用 async/await 簡化了 Promises 的語法,使程式碼更具可讀性,更接近同步流程,同時仍然是非同步的。這是使用 async/await 重寫時程式碼的外觀:
const datas =[ {name:"kishan",profession:"software Engineer"}, {name:"Anuj",profession:"software Engineer"} ] function getDatas(){ setTimeout(() => { datas.forEach((data,index)=>{ console.log(data.name); }) }, 1000); } function createddata(newdata,callback){ setTimeout(() => { datas.push(newdata) callback() }, 2000); }`` createddata({name:"jatin",profession:"software Engineer"},getDatas)
非同步/等待的好處:
可讀性:
程式碼讀起來就像是同步、逐步的邏輯。
沒有連結或嵌套。
錯誤處理:
使用 try...catch 區塊來實現集中且一致的錯誤處理機制。
可擴充性:
新增任務就像新增另一個等待行一樣簡單。
輸出:
運行程式碼時,您將得到:
kishan Anuj jatin
以上是回調、Promises 與 Async/Await:詳細比較的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

將矩陣電影特效帶入你的網頁!這是一個基於著名電影《黑客帝國》的酷炫jQuery插件。該插件模擬了電影中經典的綠色字符特效,只需選擇一張圖片,插件就會將其轉換為充滿數字字符的矩陣風格畫面。快來試試吧,非常有趣! 工作原理 插件將圖片加載到畫布上,讀取像素和顏色值: data = ctx.getImageData(x, y, settings.grainSize, settings.grainSize).data 插件巧妙地讀取圖片的矩形區域,並利用jQuery計算每個區域的平均顏色。然後,使用

本文討論了使用瀏覽器開發人員工具的有效JavaScript調試,專注於設置斷點,使用控制台和分析性能。

本文將引導您使用jQuery庫創建一個簡單的圖片輪播。我們將使用bxSlider庫,它基於jQuery構建,並提供許多配置選項來設置輪播。 如今,圖片輪播已成為網站必備功能——一圖胜千言! 決定使用圖片輪播後,下一個問題是如何創建它。首先,您需要收集高質量、高分辨率的圖片。 接下來,您需要使用HTML和一些JavaScript代碼來創建圖片輪播。網絡上有很多庫可以幫助您以不同的方式創建輪播。我們將使用開源的bxSlider庫。 bxSlider庫支持響應式設計,因此使用此庫構建的輪播可以適應任何

數據集對於構建API模型和各種業務流程至關重要。這就是為什麼導入和導出CSV是經常需要的功能。在本教程中,您將學習如何在Angular中下載和導入CSV文件


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

Dreamweaver CS6
視覺化網頁開發工具

禪工作室 13.0.1
強大的PHP整合開發環境