0

我有这个 xml:

<Item name="Alpha">
    <Field name="CreationDateTime">2012-04-26</Field>
    <Field name="Material" readOnly="X"> Congress </Field>
</Item>

我想把它转换成这种格式(注意节点名需要换成对应的属性名)

<Item name="Alpha">
    <CreationDateTime >2012-04-26</CreationDateTime>
    <Material readOnly="X"> Congress </Material>
</Item>

在 jquery 中最快的方法可能是什么。这必须发生在具有 1000 条记录的表中,因此它必须是有效的。

谢谢

4

1 回答 1

0

以下代码使用 jQuery 的 map 函数在文档之间进行转换。它完成了基本工作,并且可能可以进一步扩展以满足您完整文档的需求。

几个存在的问题:

  • 输出中标签的大小写是小写的,我似乎找不到一个简单的解决方案。
  • 我不知道它将如何处理数千条记录。:)

资源:

<script type="text/javascript">
$(function() {
    var XML = 
    '<Item name="Alpha">' +
    '<Field name="CreationDateTime">2012-04-26</Field>' + 
    '<Field name="Material" readOnly="X"> Congress </Field>' +
'</Item>';

$(XML).map(function() {             
    function map() {
        if ($(this).is("Item")) {
            var result = $("<Item>").attr("name", "Alpha");                     
            var children = $(this).children().map(map);


            $(children).each(function() {
                result.append(this);
            });

            return result;
        }

        if ($(this).is("Field")) {
            var name = $(this).attr("name");

            var result = $("<" + name + ">");

            // Transfer other attributes
            $(this.attributes).each(function() {
                if (this.name === "name")
                    return;

                result.attr(this.name, this.value);
            });

            result.text( $(this).text() );
            return result;
        }
    };

    var result = $(XML).map(map);
});
});
</script>
于 2012-10-04T19:38:07.907 回答