我正在使用 fast-xml-parser,它可以解析我们从 API 获得但不一致的一些数据。存在无法解析为 JS 对象的特定响应。
<?xml version="1.0" encoding="utf-8"?>
<DataSet xmlns="http://www.pepid.com/webservices/">
<xs:schema id="NewDataSet" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
<xs:element name="NewDataSet" msdata:IsDataSet="true" msdata:UseCurrentLocale="true">
<xs:complexType>
<xs:choice minOccurs="0" maxOccurs="unbounded">
<xs:element name="ContentSearchIndex">
<xs:complexType>
<xs:sequence>
<xs:element name="Pos" type="xs:int" minOccurs="0" />
<xs:element name="Content_Id" type="xs:int" minOccurs="0" />
<xs:element name="Title" type="xs:string" minOccurs="0" />
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:choice>
</xs:complexType>
</xs:element>
</xs:schema>
<diffgr:diffgram xmlns:msdata="urn:schemas-microsoft-com:xml-msdata" xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
<NewDataSet xmlns="">
<ContentSearchIndex diffgr:id="ContentSearchIndex1" msdata:rowOrder="0">
<Pos>8412</Pos>
<Content_Id>401687</Content_Id>
<Title>Headache</Title>
</ContentSearchIndex>
</NewDataSet>
</diffgr:diffgram>
</DataSet>
产生的代码如下:
return fetch(url)
.then((response) => response.text())
.then(async (text) => {
const obj = parse(text);
if (obj) {
console.log(obj);
return obj;
我从https://www.pluralsight.com/guides/fetch-and-populate-xml-data-in-react-native获得了这些代码,它可以解析一些响应,但不能解析上面提到的响应。
我需要的唯一数据是以下 JS 格式的数据,但我想使用 fast-xml-parser 正确完成。我在想我只需要一些选项来使其正确解析该响应,而无需采用逐字母阅读整个响应的骇人听闻的方法。
<Pos>8412</Pos>
<Content_Id>401687</Content_Id>
<Title>Headache</Title>