使用javascript在客户端通过 XSLT 将 XML 文档转换为 XHTML,兼容IE和Firefox
2008-12-11 12:23
1216 查看
<script type="text/javascript">
loadXML = function(fileRoute){
xmlDoc=null;
if (window.ActiveXObject){
xmlDoc = new ActiveXObject('Msxml2.DOMDocument'); xmlDoc.async=false; xmlDoc.load(fileRoute);
}
else if (document.implementation && document.implementation.createDocument){
var xmlhttp = new window.XMLHttpRequest();
xmlhttp.open("GET",fileRoute,false);
xmlhttp.send(null);
xmlDoc = xmlhttp.responseXML; //返回document对象
}
else {xmlDoc=null;}
return xmlDoc;
}
var Browser={};
Browser.isMozilla = (typeof document.implementation != 'undefined') && (typeof document.implementation.createDocument != 'undefined') && (typeof HTMLDocument!='undefined');
Browser.isIE = window.ActiveXObject ? true : false;
Browser.isFirefox = (navigator.userAgent.toLowerCase().indexOf("firefox")!=-1);
Browser.isSafari = (navigator.userAgent.toLowerCase().indexOf("safari")!=-1);
Browser.isOpera = (navigator.userAgent.toLowerCase().indexOf("opera")!=-1);
var xmlObj=loadXML("cdcatalog.xml");
var xslObj =loadXML("cdcatalog.xsl");
if(Browser.isMozilla==true){
//firefox没有实现xml.transformNode,添加transformNode方法。
Node.prototype.transformNode = function (oXslDom) {
var oProcessor = new XSLTProcessor();
oProcessor.importStylesheet(oXslDom);
var oResultDom = oProcessor.transformToDocument(this);
var xmls = new XMLSerializer();
return xmls.serializeToString(oResultDom);
}
}
document.write(xmlObj.transformNode(xslObj));
</script>
查看文件 cdcatalog.xsl cdcatalog.xml
loadXML = function(fileRoute){
xmlDoc=null;
if (window.ActiveXObject){
xmlDoc = new ActiveXObject('Msxml2.DOMDocument'); xmlDoc.async=false; xmlDoc.load(fileRoute);
}
else if (document.implementation && document.implementation.createDocument){
var xmlhttp = new window.XMLHttpRequest();
xmlhttp.open("GET",fileRoute,false);
xmlhttp.send(null);
xmlDoc = xmlhttp.responseXML; //返回document对象
}
else {xmlDoc=null;}
return xmlDoc;
}
var Browser={};
Browser.isMozilla = (typeof document.implementation != 'undefined') && (typeof document.implementation.createDocument != 'undefined') && (typeof HTMLDocument!='undefined');
Browser.isIE = window.ActiveXObject ? true : false;
Browser.isFirefox = (navigator.userAgent.toLowerCase().indexOf("firefox")!=-1);
Browser.isSafari = (navigator.userAgent.toLowerCase().indexOf("safari")!=-1);
Browser.isOpera = (navigator.userAgent.toLowerCase().indexOf("opera")!=-1);
var xmlObj=loadXML("cdcatalog.xml");
var xslObj =loadXML("cdcatalog.xsl");
if(Browser.isMozilla==true){
//firefox没有实现xml.transformNode,添加transformNode方法。
Node.prototype.transformNode = function (oXslDom) {
var oProcessor = new XSLTProcessor();
oProcessor.importStylesheet(oXslDom);
var oResultDom = oProcessor.transformToDocument(this);
var xmls = new XMLSerializer();
return xmls.serializeToString(oResultDom);
}
}
document.write(xmlObj.transformNode(xslObj));
</script>
查看文件 cdcatalog.xsl cdcatalog.xml
相关文章推荐
- 使用 JavaScript 实现 XMLHttpRequest,在IE,FireFox 上测试通过!
- 使用 JavaScript 实现 XMLHttpRequest,在IE,FireFox 上测试通过
- javascript获取iframe文档内容(兼容IE和Firefox)
- [JavaScript] 兼容IE、FireFox、Chrome等浏览器的xml处理函数(xml同步/异步加载、xsl转换、selectSingleNode、selectNodes)
- c#使用XSLT将xml文档转换为html文档
- 使用 XSLT 将 XML 转换为 XHTML
- 使用JS读取XML(兼容IE和firefox)
- .net中使用XSLT转换xml文档
- C#操作Xml:XSLT语法 在.net中使用XSLT转换xml文档示例
- [JavaScript] 兼容IE、FireFox、Chrome等浏览器的xml处理函数(xml同步/异步加载、xsl转换、selectSingleNode、selectNodes)
- javascript解析xml文件。兼容IE、firefox、Chrome
- Dom元素基本操作方法API,先记录下,方便以后使用。 W3C DOM和JavaScript很容易混淆不清。DOM是面向HTML和XML文档的API,为文档提供了结构化表示,并定义了如何通过脚本
- 兼容IE和Firefox的javascript获取iframe文档内容的变量
- 兼容IE和Firefox的javascript获取iframe文档内容的函数
- XSLT语法 在.net中使用XSLT转换xml文档示例
- c#使用XSLT将xml文档转换为html文档
- 兼容IE和firefox 操作XML的 javascript
- C#中使用XSLT文件将XML文档转换为HTML
- javascript获取iframe文档内容(兼容IE和Firefox)
- 兼容IE和Firefox的javascript获取iframe文档内容的函数