jQueryAjax异步处理Json数据详解
2023-06-13 09:15:07 时间
先我们来看一个官方的实例
使用AJAX请求来获得JSON数据,并输出结果:
复制代码代码如下:
使用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就可以了,不需要为服务器控件做模板(不过我还没遇到过这样的美工,都是美工设计好了我来改成服务器控件的模板)。
相关文章
- 数据建模之ODS层命名规范及质量规范
- MySQL低配数据库被大量数据导入时KO
- 处理异步加载数据的获取
- Redis + NodeJS 实现一个能处理海量数据的异步任务队列系统
- Windows上使用Ubuntu部署大数据环境
- 【SLAM】开源 | 一个高精度的连续时间轨迹估计框架,能够有效地融合高频和异步传感器数据!
- Mysql使用函数json_extract处理Json类型数据的方法实例
- 数据MySQL轻松操作JSON数据(mysql取json)
- 把JSON 格式数据存入MySQL(mysql存入json)
- 使用Oracle解析JSON数据(oracle解析json)
- MySQL实现增量数据同步(mysql增量同步数据)
- Mongodb异步: 改善数据读写效率的有效方法(mongodb异步)
- MSSQL查询实现数据去重的解决方法(mssql查询去重)
- MySQL中使用JSON格式存储数据(mysql中json)
- 异步更新Redis优化你的数据流(异步更新redis的数据)
- 破解JSON数据,Oracle数据库助力转换(json转oracle)
- 分布式系统中异步获取Redis数据(分布式获取redis)
- IBM 如何用数据追踪世界上最致命的传染病?
- ASP.NET2.0中数据源控件之异步数据访问
- struts2+jquery+json实现异步加载数据(自写)
- mssqlserver恢复ldf文件数据的方法
- asp.net使用js分页实现异步加载数据