首頁 > web前端 > js教程 > 非同步JS框架的作用以及實作方法_javascript技巧

非同步JS框架的作用以及實作方法_javascript技巧

WBOY
發布: 2016-05-16 15:34:35
原創
1269 人瀏覽過

從非同步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的重要性。

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板