使用XSLT导入XML的HTML页面

时间:2014-08-29 15:38:34

标签: javascript html xml xslt

我有一个HTML页面,我想在DIV中使用XML和XSLT添加一些内容,如何导入XML并评估相关的XSLT?

我已经尝试了iframe,但必须调整大小以适应内容,我还尝试使用此页面中显示的脚本:

http://msdn.microsoft.com/en-us/library/ms757854%28v=vs.85%29.aspx

但我认为这只适用于IE,这是最好的操作方式吗?

1 个答案:

答案 0 :(得分:1)

感谢w3c提供与浏览器无关的代码:

<html>
<head>
<script>
function loadXMLDoc(filename)
{
if (window.ActiveXObject)
  {
  xhttp = new ActiveXObject("Msxml2.XMLHTTP");
  }
else
  {
  xhttp = new XMLHttpRequest();
  }
xhttp.open("GET", filename, false);
try {xhttp.responseType = "msxml-document"} catch(err) {} // Helping IE11
xhttp.send("");
return xhttp.responseXML;
}

function displayResult()
{
xml = loadXMLDoc("cdcatalog.xml");
xsl = loadXMLDoc("cdcatalog.xsl");
// code for IE
if (window.ActiveXObject || xhttp.responseType == "msxml-document")
  {
  ex = xml.transformNode(xsl);
  document.getElementById("example").innerHTML = ex;
  }
// code for Chrome, Firefox, Opera, etc.
else if (document.implementation && document.implementation.createDocument)
  {
  xsltProcessor = new XSLTProcessor();
  xsltProcessor.importStylesheet(xsl);
  resultDocument = xsltProcessor.transformToFragment(xml, document);
  document.getElementById("example").appendChild(resultDocument);
  }
}
</script>
</head>
<body onload="displayResult()">
<div id="example" />
</body>
</html>

http://www.w3schools.com/xsl/xsl_client.asp