我正在尝试使用 XSLT(在 Javascript 中)来漂亮地打印机器生成的 XHTML 文档。然而,我尝试使用的各种 XSLT 都破坏了 xmlns 属性(见下文)。
这是所需输出的示例(由无缩进、紧凑的 XHTML 手工制作)。
<?xml version="1.0" encoding="UTF-8"?>
<h:html xmlns:h="http://www.w3.org/1999/xhtml" xmlns:orx="http://openrosa.org/jr/xforms" xmlns="http://www.w3.org/2002/xforms" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:jr="http://openrosa.org/javarosa">
<h:head>
<h:title>New Form1</h:title>
....
这是我得到的:
<h:html h="http://www.w3.org/1999/xhtml" orx="http://openrosa.org/jr/xforms" xmlns="http://www.w3.org/2002/xforms" xsd="http://www.w3.org/2001/XMLSchema" jr="http://openrosa.org/javarosa">
<h:head>
<h:title>New Form1</h:title>
...
请注意,第二个代码片段中“h:html”标记中的 xmlns 属性已更改。也是开始<?xml ...>
标签丢失。
这是我使用过的(众多)XSLT 之一,结果相似:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">\
<xsl:output method="xml" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="/">
<xsl:copy-of select="."/>
</xsl:template>
</xsl:stylesheet>
关于我做错了什么有什么想法吗?我是否正在尝试做不可能的事?
如果您想知道我为什么要这样做:我必须使用 GWT 作为设计 FormDesigner Web 应用程序的框架。这是输出,但对于想要进行手动编辑的技术性更强的用户来说,需要是人类可读的。 GWT 只是不做 xml pretty-print (据我目前的搜索所知)。因此,我们进入 JS 领域并尝试在那里找到解决方案。
想法/解决方案将不胜感激!
编辑:
这是使用 XSLT 的 Javascript。我调用 beautifyXML() 函数来实际执行缩进:
//var xsl_string = '<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output omit-xml-declaration="yes" indent="yes"/> <xsl:template match="node()|@*"> <xsl:copy> <xsl:apply-templates select="node()|@*"/> </xsl:copy> </xsl:template></xsl:stylesheet>';
// from: http://www.xml.com/pub/a/2006/11/29/xslt-xml-pretty-printer.html?page=3
var xsl_string = '<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">\
<xsl:output method="xml" indent="yes"/>\
<xsl:strip-space elements="*"/>\
<xsl:template match="/">\
<xsl:copy-of select="."/>\
</xsl:template>\
</xsl:stylesheet>';
var xsl = (new DOMParser()).parseFromString(xsl_string, "text/xml");
function stringToXml(xml_string) {
return (new DOMParser()).parseFromString(xml_string, "text/xml");
}
function xmlToString(xml) {
return (new XMLSerializer()).serializeToString(xml);
}
function isParseError(xml) {
try {
// console.log( xml.documentElement.firstChild.firstChild.tagName);
return xml.documentElement.tagName == "parsererror" ||
xml.documentElement.firstChild.firstChild.tagName == "parsererror";
}
catch (ex) {
return false;
}
}
function beautifyXml(input) {
var xml = stringToXml(input);
if (isParseError(xml)) {
return input;
}
var transformedXml = xslTransformation(xml, xsl);
return xmlToString(transformedXml);
}
/**
* @param xml
* @param xsl
*/
function xslTransformation(xml, xsl) {
// code for IE
if (window.ActiveXObject) {
var ex = xml.transformNode(xsl);
return ex;
}
// code for Mozilla, Firefox, Opera, etc.
else if (document.implementation && document.implementation.createDocument) {
var xsltProcessor = new XSLTProcessor();
xsltProcessor.importStylesheet(xsl);
var resultDocument = xsltProcessor.transformToFragment(xml, document);
return resultDocument;
}
}
最佳答案
我终于找到了答案(现在才抽出时间在这里发布)。
事实证明,问题不在于 XSLT 本身,而在于 javascript 调用它的方式。该行:
var resultDocument = xsltProcessor.transformToFragment(xml, document);
在我粘贴到问题中的最后一个代码示例中(靠近示例底部),应为:
var resultDocument = xsltProcessor.transformToDocument(xml, document);
(注意:transformToFragment 变为transformTo Document) 此更改会导致现有 xmlns 属性不会被忽略并且转换会正确发生。
感谢大家的帮助!评论中的问题引导我找到了正确的解决方案。
关于java - 使用 XSLT 漂亮地打印 XML/XHTML,而不会损坏 namespace 信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5657181/