jQuery学习之jQuery Ajax用法详解_Android, Python及开发编程讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Android, Python及开发编程讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 2925 | 回复: 0   主题: jQuery学习之jQuery Ajax用法详解        下一篇 
_chen
版主
等级:中校
经验:2139
发帖:39
精华:0
注册:2013-8-23
状态:离线
发送短消息息给_chen 加好友    发送短消息息给_chen 发消息
发表于: IP:您无权察看 2015-8-12 9:17:46 | [全部帖] [楼主帖] 楼主

jQuery Ajax在web应用开发中很常用,它主要包括有 ajax,get,post,load,getscript等等这几种常用无刷新操作方法,本帖会详细讲到。

我们先从最简单的方法看起,处理复杂的ajax请求时,jQuery使用jQuery.ajax()方法进行处理。在jQuery中有一些简单的方法,它对jQuery.ajax()方法进行了封装,使得我们在处理一些简单的Ajax事件时,不需要使用jQuery.ajax()方法,其中有些方法在之前的文章中已经出现过了,相信大家很快便能掌握。当然,本篇后半部分会对jQuery.ajax()方法做非常具体的说明,因为它是本篇的重中之重。

以下5个方法执行一般Ajax请求的简短形式,在处理复杂的Ajax请求时应该使用jQuery.ajax().

1.load(url,[data],[callback])
载入远程HTML文件代码并插入至DOM中,默认使用GET方式,传递参数时自动转换为POST方式。
url:要载入的远程url地址
data:发送至服务器的key/value 数据
callback:载入成功时的回调函数
示例代码如下:

//无参数、无回调函数
$("#showload").load("load.htm");
//无回调函数
$("#showload").load("load.htm", { "para": "para-value" });
$("#showload").load("load.htm", { "para": "para-value" },
function() {
      //处理
})


这里将显示加载的文件的内容Load

2.jQuery.get(url, [data], [callback])
使用get方式从服务器端获取数据。
发送请求的URL地址
要发送给服务器的数据
载入成功时回调函数
示例代码如下:    

$.get("jqueryget.htm", { "id": this.id },
function(req) {
      //成功时的回调方法
      $("#showget").html(req);
});
})


值得一提的是,此时是通过get方法获得请求,所以在获取参数值时要使用Request.QueryString,可以看看Request Request.QueryString的区别

3.jQuery.post(url, [data], [callback])
使用POST方式来进行异步请求。同jQuery.get()相比,差别在于请求的方式,所以这里不做特别的说明了,使用方法同jQuery.get()相似。

4.jQuery.getScript(url,[callback])
通过 GET 方式请求载入并执行一个JavaScript文件。这个技术在前边文章中已经提到过,也是jQuery.ajax的一种简单的使用方法,可以看看ajax加载js,所以在这里也不做特别的说明了。

5.jQuery.getJSON(url,[data],[callback])

通过get方式获取json格式的数据。
示例代码如下:    

$.getJSON("http://api.flickr.com/services/feeds/photos_public.gne?tags=cat&tagmode=any&format=json&jsoncallback=?", function(req) {
      $.each(req.items, function(i, item) {
            if (i == vnum) {
                  $("<img src="" + item.media.m + "" title="" + item.title + "" />").appendTo("#showjson");
            }
      });
});


这里有几个Ajax事件参数:beforeSend ,success ,complete ,error 。我们可以定义这些事件来很好的处理我们的每一次的Ajax请求。注意一下,这些Ajax事件里面的 this 都是指向Ajax请求的选项信息的(请参考说 get() 方法时的this的图片)。    

$.ajax({
      url: url,
      dataType: 'json',
      data: data,
      success: callback
});


可能你还没有使用过json数据,我的小站中已经好几次提到了json的使用,如果你还不熟悉json格式,可以看看jquery移动listbox的值、jQuery下json的使用实例
获得json数据
这里将随机显示一条json数据到目前为止我们总结了jQuery.ajax的五种简写方法,接下来让我们集中精神,看看jQuery.ajax()方法,在使用中,笔者也是经常使用的jQuery.ajax(),因为大多数情况,我们需要对ajax请求出错的情况进行捕捉并处理。

6.jQuery.ajax()
使用jQuery.ajax()方法获取数据,下边给个常用写法,并做了相应的注释。

$.ajax({
    url: "http://www.hzhuti.com",    //请求的url地址
    dataType: "json",   //返回格式为json
    async: true, //请求是否异步,默认为异步,这也是ajax重要特性
    data: { "id": "value" },    //参数值
    type: "GET",   //请求方式
    beforeSend: function() {
      //请求前的处理
},
success: function(req) {
      //请求成功时处理
},
complete: function() {
      //请求完成的处理
},
error: function() {
//请求出错处理
}
});


使用jQuery.ajax()
这里将显示数据

$.ajax我的实际应用例子

//1.$.ajax带json数据的异步请求
var aj = $.ajax( {
      url:'productManager_reverseUpdate',// 跳转到 action
      data:{
            selRollBack : selRollBack,
            selOperatorsCode : selOperatorsCode,
            PROVINCECODE : PROVINCECODE,
            pass2 : pass2
      },
      type:'post',
      cache:false,
      dataType:'json',
      success:function(data) {
            if(data.msg =="true" ){
                  // view("修改成功!");
                  alert("修改成功!");
                  window.location.reload();
            }else{
            view(data.msg);
      }
},
error : function() {
      // view("异常!");
      alert("异常!");
}
});
//2.$.ajax序列化表格内容为字符串的异步请求
function noTips(){
      var formParam = $("#form1").serialize();//序列化表格内容为字符串
      $.ajax({
            type:'post',
            url:'Notice_noTipsNotice',
            data:formParam,
            cache:false,
            dataType:'json',
            success:function(data){
            }
      });
}
//3.$.ajax拼接url的异步请求
var yz=$.ajax({
      type:'post',
      url:'validatePwd2_checkPwd2?password2='+password2,
data:{},
      cache:false,
      dataType:'json',
      success:function(data){
            if( data.msg =="false" ) //服务器返回false,就将validatePassword2的值改为pwd2Error,这是异步,需要考虑返回时间
            {
                  textPassword2.html("<font color='red'>业务密码不正确!</font>");
                  $("#validatePassword2").val("pwd2Error");
                  checkPassword2 = false;
                  return;
            }
      },
error:function(){}
});
//4.$.ajax拼接data的异步请求
$.ajax({
url:'<%=request.getContextPath()%>/kc/kc_checkMerNameUnique.action',
type:'post',
data:'merName='+values,
async : false, //默认为true 异步  
error:function(){
      alert('error');
},
success:function(data){
$("#"+divs).html(data);
}
});


本篇的jQuery ajax使用就总结到这里,当然还有一些方法并未能全部的总结。如ajaxStart()、ajaxStop()等,在以后使用中,我会把它们也总结下来。




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论