回調、Promises 與 Async/Await:詳細比較
簡介:
非同步程式設計是現代 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中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

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

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。
