我在 JavaScript 中查看了将字符串转换为 XML 文档,但在我的情况下找不到解决方案,有人可以帮助我吗?
我有一个像下面这样的字符串,我想将它转换为 XML 对象,我该怎么做?
<list>
<Response>
<cfgId>280</cfgId>
<recommendations><Rule>
<name>simple rule</name>
<category>none</category>
<severity>warning</severity>
<ruleEvalResult>true</ruleEvalResult>
<actionResult> Current value of maxfilesperproc is 32
increase it to 1024</actionResult>
</Rule></recommendations>
</Response>
</list>
Run Code Online (Sandbox Code Playgroud)
上述xml的可读版本
<list>
<Response>
<cfgId>280</cfgId>
<recommendations>
<Rule> <name>simple rule</name> <category>none</category> <severity>warning</severity> <ruleEvalResult>true</ruleEvalResult> <actionResult>Current value of maxfilesperproc is 32
increase it to 1024</actionResult> </Rule>
</recommendations>
</Response>
</list>
Run Code Online (Sandbox Code Playgroud)
更新,这是我尝试过的。
var xml;
$.post("/csm/rules.action",
{ sessiontoken: sessiontoken,
cfgid: cfgid},
function(xmldata)
{
xml=$(xmldata);
}
);
var htmlTable = $('<table></table>');
$(xml).find('Response').each(function(){
var cid = $(this).find('cfgId').text();
alert(cid+", "+cfgid);
if(cid==cfgid) {
// Now grab the entitiy string
var newXmlString = $(xml).find('recommendations').text();
// Convert the entities to HTML and return a jQuery object
var newXml = $("<div/>").html(newXmlString);
// NOW we can get at the inner XML
var ruleseverity=$(newXml).find('severity').text();
if(ruleseverity=="warning") {
var rulename=$(newXml).find('name').text();
var rulecategory=$(newXml).find('category').text();
var ruleresult=$(newXml).find('ruleEvalResult').text();
var ruleactionresult=$(newXml).find('actionResult').text();
htmlTable.append('<tr><td>RuleName:'+rulename+'</td><td>RuleResult: '+ruleactionresult+'</td></tr>');
}
}
});
Run Code Online (Sandbox Code Playgroud)
我htmlTable稍后在代码中添加'<div class="block">'+htmlTable+'</div>'
我根本不提醒
尽管它可能与 JavaScript 中的Convert String to XML Document重复 - 我们可以使用jquery的一些帮助来 解码 html 实体
我做了一个小提琴
// the $() creates a jQuery object of the outer XML
var xml = $('<list><Response><cfgId>280</cfgId><recommendations><Rule><name>simple rule</name><category>none</category><severity>warning</severity><ruleEvalResult>true</ruleEvalResult><actionResult> Current value of maxfilesperproc is 32 increase it to 1024</actionResult></Rule></recommendations></Response></list>');
Run Code Online (Sandbox Code Playgroud)
更新这是更正确的:
http://jsfiddle.net/mplungjan/ppj3nquL/
// the $() creates a jQuery object of the outer XML
var xml = $('<list><Response><cfgId>280</cfgId><recommendations><Rule><name>simple rule</name><category>none</category><severity>warning</severity><ruleEvalResult>true</ruleEvalResult><actionResult> Current value of maxfilesperproc is 32 increase it to 1024</actionResult></Rule></recommendations></Response></list>');
Run Code Online (Sandbox Code Playgroud)
var xmlString = '<list><Response><cfgId>280</cfgId><recommendations><Rule><name>simple rule</name><category>none</category><severity>warning</severity><ruleEvalResult>true</ruleEvalResult><actionResult> Current value of maxfilesperproc is 32 increase it to 1024</actionResult></Rule></recommendations></Response></list>';
var xmlDocument = $.parseXML(xmlString);
var $xml = $(xmlDocument);
var cfgid = 280;
var htmlTable = $('<table></table>');
$xml.find('Response').each(function() {
var cid = $(this).find('cfgId').text();
if (cid == cfgid) {
// Now grab the entitiy string
var newXmlString = $(this).find('recommendations').text();
// Convert the entities to HTML and return a jQuery object
var newXml = $("<div/>").html(newXmlString);
// NOW we can get at the inner XML
var ruleseverity = $(newXml).find('severity').text();
if (ruleseverity == "warning") {
var rulename = $(newXml).find('name').text();
var rulecategory = $(newXml).find('category').text();
var ruleresult = $(newXml).find('ruleEvalResult').text();
var ruleactionresult = $(newXml).find('actionResult').text();
htmlTable.append('<tr><td>RuleName:' + rulename + '</td><td>RuleResult: ' + ruleactionresult + '</td></tr>');
}
}
});
$("#container").append(htmlTable);Run Code Online (Sandbox Code Playgroud)
td {
border: 1px solid black
}Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
15309 次 |
| 最近记录: |