從非同步JS的重要性開始說起,再引入非同步js框架,一步步的深入了解非同步JS。
1.非同步JS的重要性
隨著Web平台地位的提升,霸占瀏覽器的JavaScript語言也成為了世界上最受歡迎的語言之一,甚至透過Node.js進入了伺服器程式設計領域。 JavaScript的一個重要特性就是“不能阻塞”,這裡的“不能”是指“不應該”而不是“無法”的意思(只要提供阻塞的API)。
JavaScript是一門單線程語言,因此一旦有某個API阻塞了當前線程,就相當於阻塞了整個程序,所以「非同步」在JavaScript程式設計中佔有很重要的地位。非同步程式對程式執行效果的好處這裡就不多談了,但是非同步程式設計對於開發者來說十分麻煩,它會將程式邏輯拆分地支離破碎,語義完全丟失。
你是不是也曾因為ajax非同步,只能在回呼函數裡嵌套邏輯而發狂?這樣的程式碼看起來非常糟糕。如果使用同步,程式碼可以不用嵌套。但如果請求時間過長,又會因為執行緒阻塞,導致瀏覽器假死。真是非常苦惱。看來優雅的程式碼和良好的使用者體驗不能兼得了。
2.非同步JS框架登場
假如現在有3個ajax請求,分別為A,B,C。 A執行完後才能執行B,B執行完後才能執行C。這樣我們就得嵌套了,在A的回呼函數裡執行B,然後在B的回呼函數裡執行C。這樣的程式碼非常不友善。
本著『專業造輪子』的原則,我的非同步JS框架出發了!
大致結構-
var js = new AsyncJs(); var func = js.Build(function () { var a = _$Async({ url: "", success: function () { } }); var b = _$Async({ url: "", success: function () { } }); var c = _$Async({ url: "", success: function () { } }); }); eval(func);
a,b,c會依序執行,且執行緒不會阻塞。
優勢
1.良好的體驗。全程異步,執行緒不會阻塞。
2.代碼優雅。不需要複雜的嵌套,框架幫你自動完成嵌套工作,你只需要專注於編碼本身,易於維護。
3.簡單易用。 build(function(){ }) 你可以理解成C#的Thread,我開多一個線程去執行function(){} (JS是單線程的,這點要強調下!)
new Thread(() => { //dosomething });
4.簡單易擴充。 (請將所有要執行的方法用_$Async‘包住')
5.易於調試。
缺點
1.build(function(){ }),函數內不支援自訂局部變量,如var a=1;
如果想使用局部變量,只能:
var a = _$Async(function () { return 1; });
2._$Async();必須以‘;'結尾。
3.build(function(){ }) 函數內不能直接呼叫外部函數,如
function Test() { var TestMethod = function () { alert(1); }; var func = js.Build(function () { TestMethod(); }); }
請使用
function Test() { var TestMethod = function () { alert(1); }; var func = js.Build(function () { _$Async(function () { TestMethod(); }); }); }
也許大家會好奇,到底如何實現的?又或者為什麼不將eval(r)封裝起來?
實作原理其實就是分析Build內的函數,然後將它動態的組合、巢狀起來,然後再執行。至於eval不封裝起來的原因是如果封裝起來,將無法使用外部變量,因此必須將它放出來。
3.測試程式碼及效果
<head runat="server"> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title></title> <script src="jquery-1.8.2.min.js"></script> <script src="AsyncJavaScript.js"></script> <script> function Show() { var js = new AsyncJs(); var url = "WebForm1.aspx"; var func = js.Build(function () { _$Async(function () { alert("点击后开始第一次ajax请求"); }); _$Async({ url: url, data: { val: "第一次ajax请求" }, success: function (data) { alert("第一次请求结束,结果:" + data); } }); _$Async(function () { alert("点击后开始第二次ajax请求"); }); var result = _$Async({ url: url, data: { val: "第二次ajax请求" }, success: function (data) { return data; } }); _$Async(function () { alert("第二次请求结束,结果:" + result); }); }); eval(func); } </script> </head> <body> <form id="form1" runat="server"> <div> <input type="button" onclick="Show()" value="查询" /> <input type="text" /> </div> </form> </body> </html>
後台C#代碼
protected void Page_Load(object sender, EventArgs e) { string val = Request.QueryString["val"]; if (!string.IsNullOrEmpty(val)) { Thread.Sleep(2000); Response.Write(val + "返回结果"); Response.End(); } }
效果圖:
可以看到完全是依序執行,且執行緒無阻塞。
以上就是介紹了非同步JS框架的作用以及實現方法,希望對大家的學習有所幫助,真正理解非同步js的重要性。

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器