利用jquery如何從json中讀取數(shù)據(jù)追加到html中
JSON 格式
json 是 Ajax 中使用頻率最高的數(shù)據(jù)格式,在瀏覽器和服務(wù)器中之間的通訊可離不開它。
JSON 格式說明
需要特別注意的是,在 JSON 中的屬性名是需要使用引號引起來的。
1.下載安裝jquery
可通過下面的方法引入在線版本的js:
<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
參考安裝文檔:http://www.dhdzp.com/zt/jquerydown.htm
2.準備一個json格式的文件,后綴可以不是.json
例如下面是result.json的格式
{
"title":"【UI測試結(jié)果】-轉(zhuǎn)轉(zhuǎn)2017/1/23 14:47",
"starttime":"2017/1/23 15:00 45",
"endtime":"2017/1/23 15:01 42",
"passcount":10,
"failurecount":5,
"resultinfo":[
{
"name":"發(fā)布",
"moudle":"Publish",
"pass":"true",
"onecepass":"true",
"log":"true"
},
{
"name":"登錄",
"moudle":"Login",
"pass":"false",
"onecepass":"true",
"log":"asserterrorlog",
"failurereason":{
"errorlog":"asserterror",
"errorimg":"./登錄.jpg"
}
}
]
}
3.通過$.getJSON獲得Json文件的數(shù)據(jù)
例如下面的例子:讀取result.json文件的內(nèi)容,存儲到result變量中,結(jié)果是一個json格式
$.getJSON('./result.json',function(result){}
4.通過【$('#元素id').after(html內(nèi)容);】將html內(nèi)容添加到定位到的元素后面
元素定位方式
$("#id"):定位到id,
$(“p"):定位到標簽p,其他標簽同理
$(“.class”):定位到class
插入html內(nèi)容位置:
- append() - 在被選元素的結(jié)尾插入內(nèi)容
- prepend() - 在被選元素的開頭插入內(nèi)容
- after() - 在被選元素之后插入內(nèi)容
- before() - 在被選元素之前插入內(nèi)容
Json數(shù)據(jù)的操作
JSON對象[key]來讀取內(nèi)容:result['title'],或者用result.”title"
數(shù)組的對象值,可以通過$.each來獲得數(shù)據(jù):
$.each(JSON數(shù)組對象,function(遍歷索引i,遍歷對象){操作遍歷的對象})
讀取result.json,追加html的代碼如下
(jquery需要寫在<script>標簽內(nèi))
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script>
$(document).ready(function(){
//使用getJSON方法讀取json數(shù)據(jù),
//注意:info.json可以是不同類型文件,只要其中的數(shù)據(jù)為json類型即可
$.getJSON('./result.json',function(result){
var html_title='';
var html_resultinfo='';
html_title += '<b>'+result["title"]+'</b>';
$('#resultitle').after(html_title);
$.each(result["resultinfo"],function(i,item){
if(item["pass"]=="true") {
html_resultinfo += '<tr><td>' + item['name'] + '</td>' +
'<td>' + item['moudle'] + '</td>' +
'<td>' + item["pass"] + '</td>' +
'<td>' + item['onecepass'] + '</td>' +
'<td id="' + item['moudle'] + '" class="collapsed" onclick="collapsedisplay(' + item['moudle'] + ')"><u style="color: blue;">展開</u></td></tr>';
html_resultinfo +='<tr id="' + item['moudle'] + 'info" class="collapsedinfo" style="display:none"><td colspan="5">' + item['log'] + '</td></tr>';
}
$('#infotitle').after(html_resultinfo);//after方法:在每個匹配的元素之后插入內(nèi)容。
});
});
</script>
</HEAD>
<BODY>
<div style="margin-top: 30px">
<div style="font-size: 30px;text-align: center">
<p id="resultitle" ></p>
</div>
</div>
<div id="resultinfo" style="clear: both;padding-top: 30px">
<table style="width: 1080px">
<tr id="infotitle">
<th style="width:360px">用例名稱</th>
<th style="width:200px">模塊名稱</th>
<th style="width:180px">是否成功</th>
<th style="width:180px">一次成功</th>
<th style="width:160px">詳情</th></tr>
</table>
</div>
</div>
</BODY>
</HTML>
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- jquery 元素控制(追加元素/追加內(nèi)容)介紹及應(yīng)用
- jQuery 追加元素的方法如append、prepend、before
- jquery?追加元素append、prepend、before、after用法與區(qū)別分析
- Jquery元素追加和刪除的實現(xiàn)方法
- jQuery動態(tài)創(chuàng)建元素以及追加節(jié)點的實現(xiàn)方法
- jquery 操作日期、星期、元素的追加的實現(xiàn)代碼
- JQuery實現(xiàn)樣式設(shè)置、追加、移除與切換的方法
- jquery 追加tr和刪除tr示例代碼
- jQuery實現(xiàn)合并/追加數(shù)組并去除重復(fù)項的方法
- js和jquery對dom節(jié)點的操作(創(chuàng)建/追加)
- jQuery為DOM動態(tài)追加事件的方法
- jQuery操作元素追加內(nèi)容示例
相關(guān)文章
Mui使用jquery并且使用點擊跳轉(zhuǎn)新窗口的實例
下面小編就為大家?guī)硪黄狹ui使用jquery并且使用點擊跳轉(zhuǎn)新窗口的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08
google jQuery 引用文件,jQuery 引用地址集合(jquery 1.2.6至jquery1.5.2)
很多網(wǎng)站都是使用這種方式引入,客戶的瀏覽器可能已經(jīng)緩存過了 jquery??梢灾苯诱{(diào)用本地的,速度更快2011-04-04
使用jquery為table動態(tài)添加行的實現(xiàn)代碼
最近,有需要做一個動態(tài)的給table,添加行,用了點時間,算是做成了。已測試過,但如果發(fā)現(xiàn)有什么bug,可以留言,歡迎拍磚。大家一起進步。2011-03-03
JQuery操作表格(隔行著色,高亮顯示,篩選數(shù)據(jù))
最近項目里對表格的操作比較多。以往我們要做一些效果的時候往往通過程序代碼來實現(xiàn),這個努力不值,因為JQuery是完全可以做到的,并且是客戶端運行,不經(jīng)過服務(wù)器處理,給用戶的反應(yīng)快,也減少了服務(wù)器壓力2012-02-02

