Java 使用XSLT漂亮地打印XML/XHTML,而不会损坏名称空间信息

Java 使用XSLT漂亮地打印XML/XHTML,而不会损坏名称空间信息,java,javascript,xml,gwt,xslt,Java,Javascript,Xml,Gwt,Xslt,我试图使用XSLT(Javascript)漂亮地打印机器生成的XHTML文档。然而,我尝试使用的各种XSLT都会破坏xmlns属性(见下文) 下面是一个所需输出的示例(由未嵌入的、紧凑的XHTML手工制作) 新表格1 .... 以下是我得到的结果: <h:html h="http://www.w3.org/1999/xhtml" orx="http://openrosa.org/jr/xforms" xmlns="http://www.w3.org/2002/xforms" xsd="

我试图使用XSLT(Javascript)漂亮地打印机器生成的XHTML文档。然而,我尝试使用的各种XSLT都会破坏xmlns属性(见下文)

下面是一个所需输出的示例(由未嵌入的、紧凑的XHTML手工制作)


新表格1
....
以下是我得到的结果:

<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>
...

新表格1
...
请注意,xmlns属性在第二个代码段的“h:html”标记中被更改。此外,开头的
标记丢失

这是我使用过的具有类似结果的XSLT(许多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(就我目前的搜索所知)。因此,我们来到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;
    }
}
//var xsl_string='';
//发件人:http://www.xml.com/pub/a/2006/11/29/xslt-xml-pretty-printer.html?page=3
var xsl_string='1〕\
\
\
\
\
\
';
var xsl=(new DOMParser()).parseFromString(xsl_string,“text/xml”);
函数stringToXml(xml_字符串){
return(newdomparser()).parseFromString(xml_string,“text/xml”);
}
函数xmlToString(xml){
返回(新的XMLSerializer()).serializeToString(xml);
}
函数isParseError(xml){
试一试{
//console.log(xml.documentElement.firstChild.firstChild.tagName);
返回xml.documentElement.tagName==“parsererror”||
xml.documentElement.firstChild.firstChild.tagName==“parsererror”;
}
捕获(ex){
返回false;
}
}
函数XML(输入){
var xml=stringToXml(输入);
if(isParseError(xml)){
返回输入;
}
var transformedXml=xslTransformation(xml,xsl);
返回xmlToString(transformedXml);
}
/**
*@param-xml
*@param xsl
*/
函数xslTransformation(xml、xsl){
//IE代码
if(window.ActiveXObject){
var ex=xml.transformNode(xsl);
退换货;
}
//Mozilla、Firefox、Opera等的代码。
else if(document.implementation&&document.implementation.createDocument){
var xsltProcessor=new xsltProcessor();
导入样式表(xsl);
var resultDocument=xsltProcessor.transformToFragment(xml,文档);
返回结果文档;
}
}

我终于找到了答案(现在才有时间在这里发布)

事实证明,问题不在于XSLT本身,而在于javascript如何调用XSLT。该行:

var resultDocument = xsltProcessor.transformToFragment(xml, document);
在我粘贴在问题中的最后一个代码示例中(在示例底部附近),应该是:

var resultDocument = xsltProcessor.transformToDocument(xml, document);
(注意:transformToFragment变为transformTo文档) 此更改将导致不忽略现有的xmlns属性,并正确进行转换


谢谢你的帮助!评论中的问题让我找到了正确的解决方案。

我终于找到了答案(现在才有时间在这里发布)

事实证明,问题不在于XSLT本身,而在于javascript如何调用XSLT。该行:

var resultDocument = xsltProcessor.transformToFragment(xml, document);
在我粘贴在问题中的最后一个代码示例中(在示例底部附近),应该是:

var resultDocument = xsltProcessor.transformToDocument(xml, document);
(注意:transformToFragment变为transformTo文档) 此更改将导致不忽略现有的xmlns属性,并正确进行转换


谢谢你的帮助!评论中的问题让我找到了正确的解决方案。

腐败不是夸大其词吗?XML是否有效?如何应用转换?您可以发布JavaScript,还是将其隐藏在自动生成的GWT代码中?XSLT很好(除了尾随的“\”之外)在
xsl:stylesheet
元素内部。@Thomas,xml是有效的,但没有意义。xmlns:orx!=orx就其作为属性的含义而言。@Mads Hansen,我已将用于进行转换的JS添加到我的帖子中。@Adewinder:xsl:copy of指令在XSLT处理器中是否有缺陷,或者这不是问题您的javascript序列化程序有一个bug。这不是夸大了吗?XML是有效的吗?您如何应用转换?您可以发布javascript,还是将其隐藏在自动生成的GWT代码中?您的XSLT很好(除了尾随的“\”在
xsl:stylesheet
元素内部。@Thomas,xml是有效的,但没有意义。xmlns:orx!=orx就其作为属性的含义而言。@Mads Hansen,我已将用于进行转换的JS添加到我的帖子中。@Adewinder:xsl:copy of指令在XSLT处理器中是否有缺陷,或者这不是问题您的javascript序列化程序有一个bug。