【鋒利的jQuery】中全域事件ajaxStart、ajaxStop不執行

來源:互聯網
上載者:User

標籤:absolute   html   put   position   error   meta   load   資料   this   

最近一直都在研究【鋒利的jQuery】,確實是一本好書,受益匪淺。但由於技術發展及版本更新等原因,裡面還是有些坑需要踩的。

比如:第六章七節中提到的全域事件ajaxStart、ajaxStop照著案例敲結果並不會執行。

在查閱資料後,發現原來在jquery1.9+版本以後,ajax全域事件需綁定到document對象上才能觸發。

下面是各版本不同寫法:

<html><head>    <meta charset="utf-8">    <style>        #loading {            position: absolute;            top:0;            left:0;            right: 0;            bottom: 0;            background: rgba(0,0,0,.2);            display: none;        }        #loading span {            position: absolute;            top: 48%;            left: 48%;        }    </style></head><body>    <div id="loading"><span>loading...</span></div>    <form id="demo">        <input type="text" value="demo1" name="demo1">        <input type="text" value="demo2" name="demo2">        <input type="text" value="demo3" name="demo3">        <input type="submit" value="提交" id="submit">    </form></body></html>
<script>    $(function(){        $("#submit").click(function(){        //  var data = $("form").serializeArray();            var data = $("form").serialize();            $.ajax({                type:"get",                url:"1.php",                data:data,                dataType:"json",                success:function(data){                    console.log(data);                },                error:function(xhr,error){                    console.log(error);                }            })        })        // 1.9 以前寫法        $("#loading").ajaxStart(function(){            $(this).show();        }).ajaxStop(function(){            $(this).hide();        })        // 1.9+ 之後寫法        $(document).ajaxStart(function(){            $("#loading").show();        }).ajaxStop(function(){            $("#loading").hide();        })
// 以上兩種簡寫
// 1.9 以前
$("#loading").on("ajaxStart ajaxStop",function(){
$(this).toggle();
})
// 1.9+ 以後
        $(document).on("ajaxStart ajaxStop",function(){            $("#loading").toggle();        })    })</script>

 

【鋒利的jQuery】中全域事件ajaxStart、ajaxStop不執行

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.