jquery ajax $.ajax()用法解析

来源:岁月联盟 编辑:exp 时间:2012-08-30

jquey ajax部分  包含以下部分

1.load( url, [data], [callback] ) :载入远程 HTML 文件代码并插入至 DOM 中。

2. jQuery.get( url, [data], [callback] ):使用GET方式来进行异步请求

3. jQuery.post( url, [data], [callback], [type] ) :使用POST方式来进行异步请求

4. jQuery.getScript( url, [callback] ) : 通过 GET 方式请求载入并执行一个 JavaScript 文件。

jQuery.ajax( options ) : 通过 HTTP 请求加载远程数据

项目中我们常常需要使用无刷新列表的请求后台,使用dwr等ajax框架,明显缺点就不介绍了,直接入正题,上代码:

[java] 
//查取所有资讯列表 
  function querySiteMessageList(pageIndex, orderFiled){ 
   //封装传递参数 
   <span style="color:#ff0000;">var obj = new Object(); 
</span>   obj.pageIndex = pageIndex; 
   obj.orderFiled = orderFiled; 
            obj.messageSignal = $("#tabSignal").val(); 
  <span style="color:#ff0000;"> $.ajax({ 
       type : "POST",   
       url : "${ctx}/siteMessage/queryMessagelist",  
       data : obj, 
       dataType: "json",   
       success : function(data)</span> {  
        var str = ""; 
        //循环输出资讯列表 
        $.each(data.rows,function(index,elem){ 
         var createTime = new Date(elem.publishTime);//获取发布时间并转换为Date类型 
         var availableDate = new Date(elem.availableDate);//获取创建时间并转换为Date类型 
          
         //发布时间 
         var createMonth = createTime.getMonth()+ 1; 
        var createHour = createTime.getHours(); 
        var createMinute = createTime.getMinutes(); 
        var createSeconds = createTime.getSeconds(); 
        //生效时间 
          var availableMonth = availableDate.getMonth()+ 1; 
         var availableDay = availableDate.getDate(); 
          
         createMonth = createMonth <10 ? "0" + createMonth : createMonth; 
         createHour = createHour <10 ? "0" + createHour : createHour; 
         createMinute = createMinute <10 ? "0" + createMinute : createMinute; 
         createSeconds = createSeconds <10 ? "0" + createSeconds : createSeconds; 
          
         availableMonth = availableMonth <10 ? "0" + availableMonth : availableMonth; 
         availableDay = availableDay <10 ? "0" + availableDay : availableDay; 
          
         str += '<tr>'; 
         str += '<td><input type="checkbox" name="ckeckedMessageId" value='+ elem.messageId +'></td>'; 
         str += '<td><span class="messageId" style="display:none">'+elem.messageId+'</span>'+elem.title+'</td>'; 
         str += '<td>'+elem.creator+'</td>'; 
         str += '<td>'+createTime.getFullYear()+ '-'+ createMonth + '-'+ createTime.getDate()+'  '; 
         str +=  createHour + ':'+ createMinute + ':'+ createSeconds +'</td>'; 
         str += '<td>'+availableDate.getFullYear()+ '-'+ availableMonth + '-'+ availableDay +'</td>'; 
         str += '<td><a href="#" onclick="updateMessage('+ elem.messageId +')">' 
         str += '<img src="${ctx}/static/common/images/sales/operation_add.png" /></a>   '; 
         str += '<a href="#" onclick="deleteOneMessage('+ elem.messageId +')"><img src="${ctx}/static/common/images/sales/operation_delete.png" /></a></td>'; 
         str += '</tr>'; 
        }); 
         
        //根据当前状态判断输出资讯还是资讯列表 
        if($("#tabSignal").val()==1){ 
         //输出资讯列表 
         $("#newslistTr").html(str);   
            //实现分页 
            $("#page_message").setPager({ RecordCount: data.count, PageIndex: pageIndex, buttonClick: pageClick }); 
        } 
        else{ 
         //输出资讯草稿列表 
         $("#draftlistTr").html(str);   
         //实现分页      www.2cto.com
         $("#page_draft").setPager({ RecordCount: data.count, PageIndex: pageIndex, buttonClick: pageClick }); 
        } 
 
       } 
   }); 
  }; 

上例描述了一个简单的请求后台获取数据列表并展示的过程,大家重点在红色部分  :

关键点有3个,GET方式提交的情况直接把参数加在url后面,url : "${ctx}/siteMessage/queryMessagelist?id="+id,

 data参数既可以用于get也可以用于post方式。传递多参数可以封装成obj对象

succes函数可以获取返回值,返回值类型由dataType指定,具体参数请参阅官方文档。

一般在succes函数里面对返回的数据进行处理。这里我取得返回数据然后输出到指定的位置

总之,jqury ajax方法可以很好的实现无刷新请求