kks*_*kks 2 javascript typescript angular angular7
我正在使用 Angular 7。
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<Employees>
<Employee>
<Name>nameOne</Name>
<Id>IdOne</Id>
</Employee>
<Employee>
<Employee-Name>empName</Employee-Name>
</Employee>
<Employee>
<Employee-Id>IdEmp</Employee-Id>
</Employee>
</Employees>
</note>
Run Code Online (Sandbox Code Playgroud)
客户端上传不同的 .XML 文件,每个文件必须有 但父节点在上传的文件中可能不同..
需要读取每个节点并进行比较 有或没有,如果是,那么我们将使用该 ID
我的代码
const parser = new xml2js.Parser({ strict: false, trim: true });
parser.parseString(uploadedXMLData, (err, result) => {
const obj: any[] = result;
console.log(result);
Object.entries(obj).forEach((data, index) => {
console.log('Data::: ', data, index);
data[0]['NOTE'].forEach((empData, indexNumber) => {
console.log('Emp Data::: ', empData, indexNumber);
});
});
});
Run Code Online (Sandbox Code Playgroud)
为了到达每个节点,尽管您需要使用递归的 XML 结构,如下所示:
function printNode(xml, key?) {
if (xml == null) {
console.log(`Node is empty`);
return;
}
if (Array.isArray(xml)) {
return xml.forEach((v) => printNode(v, key));
}
if (typeof xml === 'object') {
return Object.entries(xml).forEach(([key, v]) => printNode(v, key));
}
console.log(`${key}:${xml}`);
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
124 次 |
| 最近记录: |