我的目标是允许用户输入值,获取与所述值对应的XML,并在iframe中呈现获取的XML。
我的HTML文件中有以下jQuery代码:
$.post('VerifyServlet', { action: "getDocument", "tcNo": tcNo, "pgNo": pgNo }, function(data) {
var xml = "<?xml-stylesheet type=\"text/xsl\" href=\"../xsl/esigtest.xsl\"?>" + data;
var ifrm = document.getElementById('xmlLoader');
ifrm = (ifrm.contentWindow) ? ifrm.contentWindow : (ifrm.contentDocument.document) ? ifrm.contentDocument.document : ifrm.contentDocument;
ifrm.document.open('text/xml');
ifrm.document.write(xml);
ifrm.document.close();
});
我的servlet中的相关代码如下:
response.setContentType("text/xml");
PrintWriter out = response.getWriter();
out.println(xmlString);
然后我有我的iframe ......
...
<td colspan="3">
<iframe id="xmlLoader" frameborder="0" width="100%" height="100%"></iframe>
</td>
...
放在一起,我的iframe中显示的结果是
<?xml-stylesheet type="text/xsl" href="../xsl/esigtest.xsl"?>[object XMLDocument]
我推断[object XMLDocument]
可能是指data
,并且正在调用XMLDocument的toString
方法。但是,我真正想要的是使用XSL样式表呈现XML并显示结果。
老实说,我不知道该怎么做,所以我在text/plain
,text/xml
,application/xml
之间尝试了MIME类型的排列,但没有任何效果。有办法做我想做的事吗?
答案 0 :(得分:0)
要制作一个xml,你可以使用这个sintax
var xml = $('<xml>', { version : "1.0", encoding : "UTF-8" });
第一个参数是节点的名称,第二个参数是一个对象,其属性将成为节点的属性。
然后你可以使用jQuery方法来创建xml
var head = $('<head>');
head.appendTo(xml);