この記事では、jquery を使用して json からデータを読み取って html に追加する方法について、サンプル コードを通じて詳しく紹介します。必要な人は以下のエディタで見てみましょう。
JSON 形式
json は Ajax で最も頻繁に使用されるデータ形式であり、ブラウザとサーバー間の通信はそれから切り離せません。
JSON 形式の説明
JSON 内の属性名は引用符で囲む必要があることに注意することが重要です。
1. jquery をダウンロードしてインストールします
次の方法で js のオンライン バージョンを導入できます:
<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
インストール ドキュメントを参照してください: http://www.jb51.net/zt/jquerydown.htm
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"
}
}
]
}
3 $.getJSONを通じてJsonファイルのデータを取得します。
例えば以下の例: result.jsonを読み込む ファイルの内容がresult変数に格納され、結果がjson形式になります
$.getJSON('./result.json',function(result){}
4. [$で位置指定された要素の後にHTMLコンテンツを追加します] ('#element id').after(html content);]
要素の配置メソッド
$("#id"):定位到id,
$(“p"):定位到标签p,其他标签同理
$(“.class”):定位到class
HTMLコンテンツの位置を挿入:
- append() - 選択した要素の末尾にコンテンツを挿入します
- prepend() - 選択した要素の先頭にコンテンツを挿入します
- after() - 選択した要素の後にコンテンツを挿入します
- before() - 選択した要素の前にコンテンツを挿入します
Json データ操作
JSON オブジェクト [キー] で内容を読み取ります: result[ 'title']、または result."title" を使用します
配列のオブジェクト値は $.each を通じて取得できます:
$.each( JSON配列オブジェクト, function(traverse Index i, traverse object) { トラバースしたオブジェクトを操作する})
result.jsonを読み込み、以下のようにHTMLコードを追記します
(jqueryは<script>タグ内に記述する必要があります) )<p><br></p>
<pre class="brush:php;toolbar:false"><!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数据,
//注意: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>