浅谈jQuery中Ajax事件beforesend及各参数含义
Ajax会触发很多事件。 有两种事件,一种是局部事件,一种是全局事件:局部事件:通过$.ajax来调用并且分配。全局事件,可以用bind来绑定,用unbind来取消绑定。这个跟click/mousedown/keyup等事件类似。但他可以传递到每一个DOM元素上。 当然,你某一个Ajax请求不希望产生全局的事件,则可以设置global:false 事件的顺序如下: ajaxStart 全局事件开始新的Ajax请求,并且此时没有其他ajax请求正在进行。beforeSend 局部事件当一个Ajax请求开始时触发。如果需要,你可以在这里设置XHR对象。ajaxSend 全局事件请求开始前触发的全局事件success 局部事件请求成功时触发。即服务器没有返回错误,返回的数据也没有错误。ajaxSuccess 全局事件全局的请求成功error 局部事件仅当发生错误时触发。你无法同时执行success和error两个回调函数。ajaxError 全局事件全局的发生错误时触发complete 局部事件不管你请求成功还是失败,即便是同步请求,你都能在请求完成时触发这个事件。ajaxComplete 全局事件全局的请求完成时触发ajaxStop 全局事件当没有Ajax正在进行中的时候,触发。局部事件回调的参数在文档中写的很清楚了,这里就不累述了。 全局事件中,除了ajaxStart和ajaxStop之外,其他的事件都有3个参数 event,XMLHttpRequest,ajaxOptions 第一个是事件,第二个是XHR对象,第三个参数最有用,是当时调用这个ajax的时候的参数。 对于ajaxError,还有第四个参数thrownError,只有当异常发生时才会被传递。 我们可以利用ajaxOptions来写一个全局的ajax事件。 比如对于这个例子, 这样我们就可以很方便的全局地在某个地方显示当前的ajax状态。 当然,之前说了,第三个参数实际上是传递给ajax的参数。get/post/load/getScript/getJSON等方法本质上都是调用ajax方法的,所以ajaxOptions.url属性总是有效的。 还有更丰富的例子。 如果你用ajax调用,还可以传递自定义参数。下面的例子我就自定义了一个msg参数给了ajax调用 最后对于load方法,还有话说。 其他的简易ajax方法,比如get,post,getJSON等,他们的回调函数都是设置了success回调。 而只有load设置的其实是complete回调。 所以,load里设置的回调函数的参数应该有2个。 XMLHttpRequest和textStatus 但实际上也并非如此。 load的回调有三个参数XMLHttpRequest.responseText,textStatus,XMLHttpRequest 所以,你可以在load的回调里 通过textStatus==”success”或者textStatus==”error”来判断是否调用成功。 或者用XMLHttpRequest.status属性判断是200还是404或者其他的。 这点上,我认为比普通的get/post等方法更先进。如果要单数设置每get的error是不可能的。但是设置一个全局的ajaxError其实也是不错的选择 以上这篇浅谈jQuery中Ajax事件beforesend及各参数含义就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |