Ajax会触发很多事件。
有两种事件,一种是局部事件,一种是全局事件:
局部事件:通过$.ajax来调用并且分配。
- $.ajax({
- beforeSend: function(){
- // Handle the beforeSend event
- },
- complete: function(){
- // Handle the complete event
- }
- // ...
- });
全局事件,可以用bind来绑定,用unbind来取消绑定。这个跟click/mousedown/keyup等事件类似。但他可以传递到每一个DOM元素上。
- $("#loading").bind("ajaxSend", function(){ //使用bind
-
$(this).show(); - }).ajaxComplete(function(){ //直接使用ajaxComplete
-
$(this).hide(); - });
当然,你某一个Ajax请求不希望产生全局的事件,则可以设置global:false
- $.ajax({
- url: "test.html",
- 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事件。
比如
- $("#msg").beforeSend(function(e,xhr,o) {
-
$(this).html("正在请求"+o.url); - }).ajaxSuccess(function(e,xhr,o) {
-
$(this).html(o.url+"请求成功"); - }).ajaxError(function(e,xhr,o) {
-
$(this).html(o.url+"请求失败"); - });
对于这个例子,
这样我们就可以很方便的全局地在某个地方显示当前的ajax状态。
当然,之前说了,第三个参数实际上是传递给ajax的参数。get/post/load/getScript/getJSON等方法本质上都是调用ajax方法的,所以ajaxOptions.url属性总是有效的。
还有更丰富的例子。
如果你用ajax调用,还可以传递自定义参数。下面的例子我就自定义了一个msg参数给了ajax调用
- //自定义参数msg
- $.ajax({url:"test1.html",type:"get",msg:"页面一"});
- $.ajax({url:"test2.html",type:"get",msg:"页面二"});
- $.ajax({url:"test3.html",type:"get",msg:"页面三"});
- $.ajax({url:"test4.html",type:"get",msg:"页面四"});
- //这里就能获取到自定义参数msg。
- //这可以用来区别对待不同的ajax请求。
- $("#msg").beforeSend(function(e,xhr,o) {
-
$(this).html("正在请求"+o.msg); - }).ajaxSuccess(function(e,xhr,o) {
-
$(this).html(o.msg+"请求成功"); - }).ajaxError(function(e,xhr,o) {
-
$(this).html(o.msg+"请求失败"); - });
最后对于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其实也是不错的选择。
鼠标事件是在用户移动鼠标光标或者使用任意鼠标键点击时触发的以下是具体事件的介绍:
(1):click事件:click事件于用户在元素敲击鼠标左键,并在相同元素上松开左键时触发。
(2):dbclick事件:dbclick事件在用户完成迅速连续的两次点击之后触发,双击的速度取决于操作系统的设置。一般双击事件在页面中不经常使用。
(3):mousedown事件:mousedown事件在用户敲击鼠标键时触发,跟keydown事件不一样,该事件仅在按下鼠标时触发。
(4):mouseup事件:mouseup事件在用户松开鼠标时触发,如果在与按下鼠标的元素相同元素上松开,那么click事件也会触发。
(5):mouseover事件:mouseover事件于用户把鼠标从一个元素移动到另外一个元素上时触发,如果需要知道来自那个元素可以使用,relatedTagrget属性。
(6):mouseout事件:mouseout事件于用户把鼠标移出一个元素时触发,这包括从父元素移动到子元素上,或者使用键盘跳到元素上。
(5)和(6)这两个事件一般不常用,很难实现与用户的交互,也就是说不易捕获用户事件。
(7):mouseenter事件:mouseenter事件是在用户光标进入元素上时触发。
(8):mouseleaver事件:mouseleaver事件是在用户的光标离开元素时触发。
(7)和(8)这两个事件一般连起来使用,在jQuery中可以使用hover这个函数来代替这两个函数。