通过jquery,从json中读取数据追加到html中
Posted 每天1990
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了通过jquery,从json中读取数据追加到html中相关的知识,希望对你有一定的参考价值。
1.下载安装jquery
可通过下面的方法引入在线版本的js:
<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
2.准备一个json格式的文件,后缀可以不是.json
例如下面是result.json的格式
{
"title":"【UI测试结果】-转转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":"发布",
"moudle":"Publish",
"pass":"true",
"onecepass":"true",
"log":"true"
},
{
"name":"登录",
"moudle":"Login",
"pass":"false",
"onecepass":"true",
"log":"asserterrorlog",
"failurereason":{
"errorlog":"asserterror",
"errorimg":"./登录.jpg"
}
}
]
}
"title":"【UI测试结果】-转转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":"发布",
"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文件的数据
例如下面的例子:读取result.json文件的内容,存储到result变量中,结果是一个json格式
$.getJSON(‘./result.json‘,function(result){}
4.通过【$(‘#元素id‘).after(html内容);】将html内容添加到定位到的元素后面
元素定位方式
$("#id"):定位到id,
$(“p"):定位到标签p,其他标签同理
$(“.class”):定位到class
插入html内容位置:
- append() - 在被选元素的结尾插入内容
- prepend() - 在被选元素的开头插入内容
- after() - 在被选元素之后插入内容
- before() - 在被选元素之前插入内容
Json数据的操作
JSON对象[key]来读取内容:result[‘title’],或者用result.”title"
数组的对象值,可以通过$.each来获得数据:
$.each(JSON数组对象,function(遍历索引i,遍历对象){操作遍历的对象})
读取result.json,追加html的代码如下
(jquery需要写在<script>标签内)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<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 src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script>
$(document).ready(function(){
//使用getJSON方法读取json数据,
//使用getJSON方法读取json数据,
//注意:info.json可以是不同类型文件,只要其中的数据为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方法:在每个匹配的元素之后插入内容。
});
});
</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>
<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>
以上是关于通过jquery,从json中读取数据追加到html中的主要内容,如果未能解决你的问题,请参考以下文章