主頁 > 知識庫 > Ajax在請求過程中顯示進度的簡單實現(xiàn)

Ajax在請求過程中顯示進度的簡單實現(xiàn)

熱門標簽:服務器配置 團購網(wǎng)站 電子圍欄 阿里云 銀行業(yè)務 Mysql連接數(shù)設置 Linux服務器 科大訊飛語音識別系統(tǒng)

Ajax在Web應用中使用得越來越頻繁。在進行Ajax調用過程中一般都具有這樣的做法:顯示一個GIF圖片動畫表明后臺正在工作,同時阻止用戶操作本頁面(比如Ajax請求通過某個按鈕觸發(fā),用戶不能頻繁點擊該按鈕產(chǎn)生多個并發(fā)Ajax請求);調用完成后,圖片消失,當前頁面運行重新編輯。以下圖為例,頁面中通過一個Load鏈接以Ajax請求的方式加載數(shù)據(jù)(左)。當用戶點擊該鏈接之后,Ajax請求開始,GIF圖片顯示“Loading“狀態(tài),同時當前頁面被“罩住”防止用戶繼續(xù)點擊Load按鈕(中);Ajax請求完成被返回響應的結果,結果被呈現(xiàn)出來的同時,GIF圖片和“遮罩”同時消失(右)。

源碼下載

    在這里我同樣以ASP.NET MVC應用為例,提供一種簡單的實現(xiàn)方式。我們GIF圖片和作為遮罩的div>定義在布局文件中,并為它們定制了相應的CSS。其中GIF和遮罩div>的z-index分別設置為2000和1000(這個任意,只要能夠讓遮罩的div>遮住當前頁面,GIF圖片顯示在最上層即可)。后者通過設置position、top、bottom、left和right是它可以遮住整個頁面,并且將其背景設置為黑色。

  !DOCTYPE html>
  html>
    head>
      title>@ViewBag.Title/title>  
      style type="text/css">
        .hide{displaynone }
        .progress{z-index }
        .mask{position fixed;top ;right ;bottom ;left ; z-index ; background-color #}
      /style>   
      ...
    /head>
    body> 
      div>@RenderBody()/div>
      img id="progressImgage" class="progress hide" alt="" src="@Url.Content("~/Images/ajax-loader.gif")"/>
      div id="maskOfProgressImage" class="mask hide">/div>
    /body>
  /html>

然后我們通過如下的代碼為jQuery定義了另一個實現(xiàn)Ajax調用的方法ajax2,該方法依然調用$.ajax(options)實現(xiàn)Ajax調用。在ajax2方法中我們將options參數(shù)complete屬性進行了“封裝”,讓可以將顯示出來的GIF圖片和遮罩div>隱藏起來。同時覆蓋了options的async屬性,是之總是以異步方式執(zhí)行,因為只有這樣瀏覽器才不能被鎖住,GIF也才能正常顯示。在調用$.ajax(options)進行Ajax請求之前,我們將GIF圖片和遮罩div>顯示出來,并且將其定位在正中央。遮罩div>的透明度進行了相應設置,所以會出現(xiàn)上圖(中)的效果。

 !DOCTYPE html>
  html>
    head>
      ...
      script type="text/javascript" src="@Url.Content("~/Scripts/jquery-...min.js")">/script>
      script type="text/javascript">
        $(function () {
          $.ajax = function (options) {
            var img = $("#progressImgage");
            var mask = $("#maskOfProgressImage");
            var complete = options.complete;
            options.complete = function (httpRequest, status) {
              img.hide();
              mask.hide();
              if (complete) {
                complete(httpRequest, status);
              }
            };
            options.async = true;
            img.show().css({
              "position" "fixed",
              "top" "%",
              "left" "%",
              "margin-top" function () { return - * img.height() / ; },
              "margin-left" function () { return - * img.width() / ; }
            });
            mask.show().css("opacity", ".");
            $.ajax(options);
          };
        });
      /script>
    /head>
    ...
  /html>

那么現(xiàn)在進行Ajax調用的時候只需要調用$.ajax2就可以,如下所示的是實例中“Load”鏈接的click事件的注冊代碼:

  a href="#" id="load">Load/a>
  div id="result">/div>
  script type="text/javascript">
    $("#load").click(function () {
      $.ajax ({
        url '@Url.Action("GetContacts")',
        success function(result)
        {
          $("#result").html(result);
        }
      });
    });
  /script>
您可能感興趣的文章:
  • 解決火狐瀏覽器下JS setTimeout函數(shù)不兼容失效不執(zhí)行的方法
  • 修改js Calendar日歷控件 兼容IE9/谷歌/火狐
  • 解決ExtJS在chrome或火狐中正常顯示在ie中不顯示的瀏覽器兼容問題
  • 設為首頁加入收藏兼容360/火狐/谷歌/IE等主流瀏覽器的代碼
  • 純js實現(xiàn)div內圖片自適應大小(已測試,兼容火狐)
  • Ajax請求過程中下載文件在FireFox(火狐)瀏覽器下的兼容問題

標簽:江蘇 衢州 衡水 蚌埠 廣元 棗莊 萍鄉(xiāng) 大理

巨人網(wǎng)絡通訊聲明:本文標題《Ajax在請求過程中顯示進度的簡單實現(xiàn)》,本文關鍵詞  ;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266