異步JS框架的作用以及實現(xiàn)方法
從異步JS的重要性開始說起,再引入異步j(luò)s框架,一步步的深入了解異步JS。
1.異步JS的重要性
隨著Web平臺地位的提升,霸占著瀏覽器的JavaScript語言也成為了世界上最流行的語言之一,甚至通過Node.js進(jìn)入了服務(wù)器編程領(lǐng)域。JavaScript的一個重要特性便是“不能阻塞”,這里的“不能”是指“不應(yīng)該”而不是“無法”的意思(只要提供阻塞的API)。
JavaScript是一門單線程語言,因此一旦有某個API阻塞了當(dāng)前線程,就相當(dāng)于阻塞了整個程序,所以“異步”在JavaScript編程中占有很重要的地位。異步編程對程序執(zhí)行效果的好處這里就不多談了,但是異步編程對于開發(fā)者來說十分麻煩,它會將程序邏輯拆分地支離破碎,語義完全丟失。
你是不是也曾因為ajax異步,只能在回調(diào)函數(shù)里嵌套邏輯而發(fā)狂?這樣的代碼看起來非常糟糕。如果使用同步,代碼可以不用嵌套。但如果請求時間過長,又會因為線程阻塞,導(dǎo)致瀏覽器假死。真是非??鄲馈?磥韮?yōu)雅的代碼和良好的用戶體驗不能兼得了。
2.異步JS框架登場
假如現(xiàn)在有3個ajax請求,分別為A,B,C。A執(zhí)行完后才能執(zhí)行B,B執(zhí)行完后才能執(zhí)行C。這樣我們就不得不嵌套了,在A的回調(diào)函數(shù)里執(zhí)行B,然后在B的回調(diào)函數(shù)里執(zhí)行C。這樣的代碼非常不友好。
本著‘專業(yè)造輪子'的原則,我的異步JS框架出發(fā)了!
大致結(jié)構(gòu)-
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會按順序執(zhí)行,且線程不會阻塞。
優(yōu)勢
1.良好的體驗。全程異步,線程不會阻塞。
2.代碼優(yōu)雅。不需要復(fù)雜的嵌套,框架幫你自動完成嵌套工作,你只需要關(guān)注編碼本身,易于維護(hù)。
3.簡單易用。build(function(){ }) 你可以理解成C#的Thread,我開多一個線程去執(zhí)行function(){} (JS是單線程的,這點要強(qiáng)調(diào)下?。?/p>
new Thread(() =>
{
//dosomething
});
4.簡單易擴(kuò)展。(請將所有要執(zhí)行的方法用_$Async‘包住')
5.易于調(diào)試。
缺點
1.build(function(){ }),函數(shù)內(nèi)不支持自定義局部變量,如var a=1;
如果想使用局部變量,只能:
var a = _$Async(function () {
return 1;
});
2._$Async();必須要以‘;'結(jié)尾。
3.build(function(){ }) 函數(shù)內(nèi)不能直接調(diào)用外部函數(shù),如
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();
});
});
}
也許大家會好奇,到底如何實現(xiàn)的?又或者為什么不將eval(r)封裝起來?
實現(xiàn)原理其實就是分析Build內(nèi)的函數(shù),然后將它動態(tài)的組合、嵌套起來,然后執(zhí)行。至于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("第一次請求結(jié)束,結(jié)果:" + data);
}
});
_$Async(function () {
alert("點擊后開始第二次ajax請求");
});
var result = _$Async({
url: url,
data: { val: "第二次ajax請求" },
success: function (data) {
return data;
}
});
_$Async(function () {
alert("第二次請求結(jié)束,結(jié)果:" + 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 + "返回結(jié)果");
Response.End();
}
}
效果圖:

可以看到完全是按順序執(zhí)行,并且線程無阻塞。
以上就是介紹了異步JS框架的作用以及實現(xiàn)方法,希望對大家的學(xué)習(xí)有所幫助,真正理解異步j(luò)s的重要性。
- ajax 異步獲取數(shù)據(jù)實現(xiàn)代碼 (js創(chuàng)建ajax對象)
- js 異步處理進(jìn)度條
- js 實現(xiàn)圖片預(yù)加載(js操作 Image對象屬性complete ,事件onload 異步加載圖片)
- 詳談 Jquery Ajax異步處理Json數(shù)據(jù).
- js異步加載的三種解決方案
- jQuery Ajax異步處理Json數(shù)據(jù)詳解
- js 異步操作回調(diào)函數(shù)如何控制執(zhí)行順序
- js中同步與異步處理的方法和區(qū)別總結(jié)
- AMD異步模塊定義介紹和Require.js中使用jQuery及jQuery插件的方法
- jquery的ajax異步請求接收返回json數(shù)據(jù)實例
- 我的Node.js學(xué)習(xí)之路(三)--node.js作用、回調(diào)、同步和異步代碼 以及事件循環(huán)
- 使用jquery.upload.js實現(xiàn)異步上傳示例代碼
- asp.net+ajaxfileupload.js 實現(xiàn)文件異步上傳代碼分享
- 詳談nodejs異步編程
- angularjs 處理多個異步請求方法匯總
相關(guān)文章
微信小程序用戶授權(quán)獲取手機(jī)號(getPhoneNumber)
這篇文章主要給大家介紹了關(guān)于微信小程序用戶授權(quán)獲取手機(jī)號的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
Javascript拖拽&拖放系列文章3之細(xì)說事件對象
Javascript中的事件對象其實和.NET中繼承自EventArgs類的派生類類似,用來給事件處理程序傳遞狀態(tài)信息,從而進(jìn)行相應(yīng)的操作。這一篇文章將講述Javascript事件對象中和實現(xiàn)拖拽功能相關(guān)的幾個屬性,并在最后將IE事件模型和標(biāo)準(zhǔn)DOM事件模型的差異封裝到一個類中,從而適應(yīng)所有的瀏覽器。2008-09-09
通過Javascript將數(shù)據(jù)導(dǎo)出到外部Excel文檔的函數(shù)代碼
通過Javascript將數(shù)據(jù)導(dǎo)出到外部Excel文檔的函數(shù)代碼,需要的朋友可以參考下2012-06-06
JS實現(xiàn)延遲隱藏功能的方法(類似QQ頭像鼠標(biāo)放上展示信息)
下面小編就為大家分享一篇JS實現(xiàn)延遲隱藏功能的方法(類似QQ頭像鼠標(biāo)放上展示信息),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12
ES6代碼轉(zhuǎn)ES5詳細(xì)教程(babel安裝使用教程)
Babel 是一個廣泛使用的 ES6 轉(zhuǎn)碼器,可以將 ES6 代碼轉(zhuǎn)為 ES5 代碼,從而在老版本的瀏覽器執(zhí)行,這意味著,你可以用 ES6 的方式編寫程序,又不用擔(dān)心現(xiàn)有環(huán)境是否支持,這篇文章主要介紹了ES6代碼轉(zhuǎn)ES5教程(babel安裝使用教程),需要的朋友可以參考下2023-01-01
注意 JavaScript 中 RegExp 對象的 test 方法
注意 JavaScript 中 RegExp 對象的 test 方法...2007-01-01

