jQuery ist eine browserübergreifende JavaScript-Bibliothek, die Operationen zwischen HTML und JavaScript vereinfacht. In praktischen Anwendungen führt die direkte Verwendung der Funktion json_encode() dazu, dass die chinesischen Zeichen in der Form „u***“ codiert werden. Dieses Problem wurde seit PHP5.4 gelöst um das Problem der Kodierung chinesischer Schriftzeichen zu lösen. In diesem Artikel stellen wir Ihnen hauptsächlich die relevanten Informationen zur Verwendung von JQuery zum Lesen von Daten aus JSON und zum Anhängen an HTML vor.
JSON-Format
JSON ist das am häufigsten verwendete Datenformat in Ajax für die Kommunikation zwischen Browsern und Servern ohne es.
Beschreibung des JSON-Formats
Es ist wichtig zu beachten, dass Attributnamen in JSON in Anführungszeichen gesetzt werden müssen.
1. Laden Sie jquery herunter und installieren Sie es
Sie können die Online-Version von js mit der folgenden Methode einführen:
<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
Siehe Installationsdokumentation: http://www.jb51.net/zt/jquerydown.htm
2. Bereiten Sie eine Datei im JSON-Format vor. Das Suffix darf nicht .json sein.
Das Folgende ist beispielsweise das Format von 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. Erhalten Sie die Daten der Json-Datei über $.getJSON
Zum Beispiel das folgende Beispiel: Lesen Sie den Inhalt der Datei result.json und speichern Sie ihn in der Ergebnisvariablen. Das Ergebnis ist ein JSON-Format
$.getJSON('./result.json',function(result){}
4. Fügen Sie HTML-Inhalt nach dem positionierten Element durch [$('# element id').after(html content);]
Elementpositionierungsmethode
$("#id"):定位到id, $(“p"):定位到标签p,其他标签同理 $(“.class”):定位到class
HTML-Inhaltsposition einfügen:
append() – Inhalt am Ende ausgewählter Elemente einfügen
prepend() – Inhalt am Anfang ausgewählter Elemente einfügen. Content
after() – Inhalt nach dem ausgewählten Element einfügen
before() – Inhalt vor dem ausgewählten Element einfügen
Json-Datenoperation
JSON-Objekt [Schlüssel] zum Lesen des Inhalts : result['title'], oder verwenden Sie result." title"
Der Objektwert des Arrays kann über $.each abgerufen werden:
$.each (JSON-Array-Objekt, Funktion (Index i durchqueren, Objekt durchqueren) {Operation durchquertes Objekt})
Lesen Sie result.json und hängen Sie den HTML-Code wie folgt an
(jquery muss im <script>-Tag geschrieben werden) </strong><br/></p><p class="jb51code"><br/></p><div class="code" style="position:relative; padding:0px; margin:0px;"><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>
用例名称 | 模块名称 | 是否成功 | 一次成功 | 详情 |
---|