ホームページ >ウェブフロントエンド >jsチュートリアル >jqueryはjsonデータを読み取ってhtmlで使用します
今回は、json データを読み込んで html で使用するための jquery について説明します。 jquery が json データを読み込んで html で使用する場合の 注意事項 について、実際のケースを見てみましょう。
JSON形式
json は Ajax で最も頻繁に使用されるデータ形式であり、ブラウザとサーバー間の通信は json から切り離せません。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 ファイルの内容を読み取り、結果変数に格納します。結果は json 形式です
$.getJSON('./result.json',function(result){}
。
4. [$('#element id').after(html content);] を通じて、配置された要素の後ろに HTML コンテンツを追加します 要素の配置方法
$("#id"):定位到id, $(“p"):定位到标签p,其他标签同理 $(“.class”):定位到class
HTML コンテンツの場所を挿入:
コンテンツを読み取るための JSON オブジェクト [キー]: result['title']、または result."title" を使用します
配列のオブジェクト値は $.each を通じて取得できます:
$.each(JSON 配列オブジェクト,function(トラバーサル インデックス i,
トラバーサル オブジェクト){トラバースされたオブジェクトの操作}) result.jsonを読み込んでhtmlを追記するコードは以下の通りです
(jquery は <script> タグに記述する必要があります)<p style="text-align: left;"><strong><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>
用例名称 | 模块名称 | 是否成功 | 一次成功 | 详情 |
---|