前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue:xml2json解析xml

Vue:xml2json解析xml

作者头像
沈宥
发布2024-07-11 10:20:49
650
发布2024-07-11 10:20:49
举报
文章被收录于专栏:从头开始学习测试开发

背景

  • 接口返回数据格式为xml,但结构复杂,解析过于繁琐,若转换为JSON,解析省时省力

使用教程

如何安装

npm包下载链接

【安装命令】 npm i xml2js

【引用】

代码语言:javascript
复制
import xml2js from 'xml2js';

具体实践

如果xml具体内容既包含数组,又包含字典,可以看下解析后的对比: 【原始xml数据】

代码语言:javascript
复制
<Result>
    <Message>可以预定</Message>
    <CreateOrderValidateKey></CreateOrderValidateKey>
    <ResultCode>0</ResultCode>
    <InventoryPrice>[{&#34;date&#34;:&#34;2024-05-10&#34;,&#34;price&#34;:37700,&#34;quota&#34;:9,&#34;promotionPrice&#34;:18850,&#34;dayPriceDetailList&#34;:null}]</InventoryPrice>
    <CurrencyCode></CurrencyCode>
</Result>

【解析为JSON后】

代码语言:javascript
复制
{
    "Result": {
        "Message": [
            "可以预定"
        ],
        "CreateOrderValidateKey": [
            ""
        ],
        "ResultCode": [
            "0"
        ],
        "InventoryPrice": [
            "[{\"date\":\"2024-05-11\",\"price\":37700,\"quota\":3,\"promotionPrice\":18850,\"dayPriceDetailList\":null}]"
        ],
        "CurrencyCode": [
            ""
        ]
    }
}

【转换方法调用】

代码语言:javascript
复制
xml2js.parseString(res.data, (err, result) => {
            let price_info = result.Result.InventoryPrice[0]

            for (let i = 0; i < price_info.length; i++) {
              let price = price_info[i].price
            }
});

【Tips】 上面的转换方法里,有关于price参数的解析,这个其实无法解析成功的,因为InventoryPrice[0]的value其实是字符串,无法按照数组去解析,这里必须再转换一次,将字符串转为为JSON

代码语言:javascript
复制
xml2js.parseString(res.data, (err, result) => {
            console.log(result)
            let price_info = JSON.parse(result.Result.InventoryPrice[0]);

            for (let i = 0; i < price_info.length; i++) {
              let price = price_info[i].price
              vm.total_price = vm.paid_price = vm.total_price + (price / 100)
            }
});
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-05-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 从头开始学习测试开发 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 背景
  • 使用教程
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档