zl程序教程

您现在的位置是:首页 >  大数据

当前栏目

jQueryAjax异步处理Json数据详解

数据异步JSONJSON 详解 处理 JqueryAJAX
2023-06-13 09:15:07 时间
先我们来看一个官方的实例
使用AJAX请求来获得JSON数据,并输出结果:
复制代码代码如下:

$("button").click(function(){
 $.getJSON("demo_ajax_json.js",function(result){
   $.each(result,function(i,field){
     $("div").append(field+"");
   });
 });
});
 

该函数是简写的Ajax函数,等价于:
复制代码代码如下:

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

发送到服务器的数据可作为查询字符串附加到URL之后。如果data参数的值是对象(映射),那么在附加到URL之前将转换为字符串,并进行URL编码。
传递给callback的返回数据,可以是JavaScript对象,或以JSON结构定义的数组,并使用$.parseJSON()方法进行解析。
从test.js载入JSON数据并显示JSON数据中一个name字段数据:
复制代码代码如下:
$.getJSON("test.js",function(json){
 alert("JSONData:"+json.users[3].name);
});
 
一个与asp.net实例
首先给出要传的json数据:[{"demoData":"ThisIsTheJSONData"}]
1,使用普通的aspx页面来处理
本人觉得这种方式处理起来是最简单的了,看下面的代码吧
复制代码代码如下:
$.ajax({
                                       type:"post",
                                       url:"Default.aspx",
                                       dataType:"json",
                                       success:function(data){
                                               $("input#showTime").val(data[0].demoData);
                                       },
                                       error:function(XMLHttpRequest,textStatus,errorThrown){
                                               alert(errorThrown);
                                       }
                               });

这里是后台传递数据的代码
复制代码代码如下:
Response.Clear();
Response.Write("[{"demoData":"ThisIsTheJSONData"}]");
Response.Flush();
Response.End();

这种处理的方式将传递过来的数据直接解析为json数据,也就是说这里的前台js代码可能直接把这些数据解析成json对象数据,而并非字符串数据,如data[0].demoData,这里就直接使用了这个json对象数据
2,使用webservice(asmx)来处理
这种处理方式就不会将传递过来的数据当成是json对象数据,而是作为字符串来处理的,如下代码
复制代码代码如下:
$.ajax({    
type:"post",    
url:"JqueryCSMethodForm.asmx/GetDemoData",    
dataType:"json",/*这句可用可不用,没有影响*/
contentType:"application/json;charset=utf-8",    
success:function(data){    
$("input#showTime").val(eval("("+data.d+")")[0].demoData);
//这里有两种对数据的转换方式,两处理方式的效果一样//$("input#showTime").val(eval(data.d)[0].demoData);
},    
error:function(XMLHttpRequest,textStatus,errorThrown){    
alert(errorThrown);    
}    
});

下面这里为asmx的方法代码
复制代码代码如下:
[WebMethod]    
publicstaticstringGetDemoData(){    
return"[{"demoData":"ThisIsTheJSONData"}]";    
}
 
这里的这种处理方式就把传递回来的json数据当成了字符串来处理的,所在就要对这个数据进行eval的处理,这样才能成为真正的json对象数据,
我们先来看一下html模板:
复制代码代码如下:
 <tableid="datas"border="1"cellspacing="0"style="border-collapse:collapse">
               <tr>
                   <th>
                       订单ID</th>
                   <th>
                       客户ID</th>
                   <th>
                       雇员ID</th>
                   <th>
                       订购日期</th>
                   <th>
                       发货日期</th>
                   <th>
                       货主名称</th>
                   <th>
                       货主地址</th>
                   <th>
                       货主城市</th>
                   <th>
                       更多信息</th>
               </tr>
               <trid="template">
                   <tdid="OrderID">
                   </td>
                   <tdid="CustomerID">
                   </td>
                   <tdid="EmployeeID">
                   </td>
                   <tdid="OrderDate">
                   </td>
                   <tdid="ShippedDate">
                   </td>
                   <tdid="ShippedName">
                   </td>
                   <tdid="ShippedAddress">
                   </td>
                   <tdid="ShippedCity">
                   </td>
                   <tdid="more">
                   </td>
               </tr>
           </table>

 一定要注意的就是里面所有的id属性,这个是一个关键。再来看一下AJAX请求和绑定数据的代码
复制代码代码如下:
   $.ajax({
           type:"get",//使用get方法访问后台
           dataType:"json",//返回json格式的数据
           url:"BackHandler.ashx",//要访问的后台地址
           data:"pageIndex="+pageIndex,//要发送的数据
           complete:function(){$("#load").hide();},//AJAX请求完成时隐藏loading提示
           success:function(msg){//msg为返回的数据,在这里做数据绑定
               vardata=msg.table;
               $.each(data,function(i,n){
                   varrow=$("#template").clone();
                   row.find("#OrderID").text(n.订单ID);
                   row.find("#CustomerID").text(n.客户ID);
                   row.find("#EmployeeID").text(n.雇员ID);
                   row.find("#OrderDate").text(ChangeDate(n.订购日期));
                   if(n.发货日期!==undefined)row.find("#ShippedDate").text(ChangeDate(n.发货日期));
                   row.find("#ShippedName").text(n.货主名称);
                   row.find("#ShippedAddress").text(n.货主地址);
                   row.find("#ShippedCity").text(n.货主城市);
                   row.find("#more").html("<ahref=OrderInfo.aspx?id="+n.订单ID+"&pageindex="+pageIndex+"> More</a>");                   
                   row.attr("id","ready");//改变绑定好数据的行的id
                   row.appendTo("#datas");//添加到模板的容器中
               });

这个是jQuery的AJAX方法,返回数据并不复杂,主要说明一下怎么把数据按模板的定义显示到到页面上。首先是这个“varrow=$("#template").clone();”先把模板复制一份,接下来row.find("#OrderID").text(n.订单ID);,表示找到id=OrderID的标记,设置它的innerText为相应的数据,当然也可以设置为html格式的数据。或者是通过外部的函数把数据转换成需要的格式,比如这里row.find("#OrderDate").text(ChangeDate(n.订购日期));有点服务器控件做模板绑定数据的感觉。
所有的这些,都是放在一个静态的页面里,只通过AJAX方法从后台获取数据,所有html代码如下:
复制代码代码如下:
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
   <title>test1</title>
   <scriptlanguage="javascript"type="text/javascript"src="js/jquery-latest.pack.js"></script>
   <scriptlanguage="javascript"type="text/javascript"src="js/PageDate.js"></script>
</head>
<body>
   <div>
        <div>
           <br/>
           <inputid="first"type="button"value=" << "/><inputid="previous"type="button"
               value=" < "/><inputid="next"type="button"value=" > "/><inputid="last"type="button"
                   value=" >> "/>
            <spanid="pageinfo"></span>
           <tableid="datas"border="1"cellspacing="0"style="border-collapse:collapse">
               <tr>
                   <th>
                       订单ID</th>
                   <th>
                       客户ID</th>
                   <th>
                       雇员ID</th>
                   <th>
                       订购日期</th>
                   <th>
                       发货日期</th>
                   <th>
                       货主名称</th>
                   <th>
                       货主地址</th>
                   <th>
                       货主城市</th>
                   <th>
                       更多信息</th>
               </tr>
               <trid="template">
                   <tdid="OrderID">
                   </td>
                   <tdid="CustomerID">
                   </td>
                   <tdid="EmployeeID">
                   </td>
                   <tdid="OrderDate">
                   </td>
                   <tdid="ShippedDate">
                   </td>
                   <tdid="ShippedName">
                   </td>
                   <tdid="ShippedAddress">
                   </td>
                   <tdid="ShippedCity">
                   </td>
                   <tdid="more">
                   </td>
               </tr>
           </table>
       </div>
       <divid="load"style="left:0px;position:absolute;top:0px;background-color:red">
           LOADING....
       </div>
       <inputtype="hidden"id="pagecount"/>
   </div>
</body>
</html>

PageData.js就是包括上面AJAX请求和绑定数据代码的js,整个页面连form都不用,这样做有什么好处呢。再看下面一个模板
复制代码代码如下:
        <ulid="datas">
               <liid="template">
                   <spanid="OrderID">
                       fsdfasdf
                   </span>
                   <spanid="CustomerID">
                   </span>
                   <spanid="EmployeeID">
                   </span>
                   <spanid="OrderDate">
                   </span>
                   <spanid="ShippedDate">
                   </span>
                   <spanid="ShippedName">
                   </span>
                   <spanid="ShippedAddress">
                   </span>
                   <spanid="ShippedCity">
                   </span>
                   <spanid="more">
                   </span>
               </li>
           </ul>

还是要注意id属性。大家看到这里应该明白了,不管用什么样的表现形式,只要id属性相同,就可以把数据绑定到对应的位置。这样的话,我们这些做程序的就不会因为美工的修改而修改代码了,而且美工也只要做出html就可以了,不需要为服务器控件做模板(不过我还没遇到过这样的美工,都是美工设计好了我来改成服务器控件的模板)。