<span id="loading_span" style="display:none;">...</span>
<button id="btnSubmit">提交</button>
<script type="text/javascript">
$("#loading_span").bind({
ajaxStart:function() {$(this).show();},
ajaxStop:function() {$(this).hide();}
});
$("#btnSubmit").on("click", function(){
$.ajax({
url:"php/postTest.php",
type:"GET",
data:{},
success:function(data){
data = $.parseJSON(data);
alert(data.key);
}
});
})
</script>
bind可以这样用吗?没有看到文档中有给bind传入一个对象的接口
ajaxStart ajaxStop都不是window下的方法,bind是如何定位它们的命名空间的?
效果:只要有ajax,loading就显示。
试试其它的,其它方法不能绑定到元素上
结论,是jQuery的特殊方法,这些ajaxStart和ajaxStop的事件处理程序可以绑定到任意文档元素上,jQuery是全局地触发它们,而不是在特定的元素上触发。
如果调用 jQuery.ajax()时没有设置context,其它四个方法ajaxSend, ajaxSuccess, ajaxError, ajaxComplete也可绑定到任意元素上