使用fast-xml-parser分别获取文本节点(以正确的顺序)?

问题描述 投票:0回答:1

无论我尝试什么选项,我似乎都将所有文本节点聚集在一起,而没有关于内部XML节点插入位置的任何信息。用一个简单的例子更容易解释:

<a>left <b>middle</b> right</a>

我希望这能给我这样的东西:

{
  tag: 'a',
  children: [
    'left ',
    { tag: 'b', children: ['middle'] },
    ' right',
  ]
}

确切的格式无关紧要,但是middleleftright之间。儿童元素的顺序对我很重要。使用fast-xml-parser,我得到的是以下内容:

{
  "a": {
    "#text": "left  right",
    "b": "middle",
  }
}

我不在乎其他格式,但是我丢失了有关<b>middle</b>节点位置的信息。从XML文件的JavaScript树版本开始,无法区分这些文件,因为它们都解析为相同的结构。

<a>left  right<b>middle</b></a>

<a><b>middle</b>left  right</a>

<a>left <b>middle</b> right</a>

<a>le<b>middle</b>ft  right</a>

是否有一个选项可以让我保留文本节点的顺序?

javascript node.js xml xml-parsing fast-xml-parser
1个回答
0
投票

不幸的是,似乎答案是此选项只是fast-xml-parser中不可用,根据我发现的以下问题:https://github.com/NaturalIntelligence/fast-xml-parser/issues/175。文本节点将合并为一个,并且团队成员explains认为这不是“错误,而是预期的行为”。

© www.soinside.com 2019 - 2024. All rights reserved.