从零开始开发纯血鸿蒙应用之XML解析

〇、前言

在前后端的数据传输方面,论格式化形式,JSON格式自然是首选,然而,曾经风靡一时的XML格式,也并非全然退出舞台,至今仍然发挥着作用,比如,RSS订阅中。

对于,JSON 格式的数据,ArkTS 因为是拓展自 Typescript,也就是 Javascript 的缘故,处理起来自然没什么难度,倒是 XML 格式的处理起来比较难,不过,鸿蒙SDK 对 XML 格式的数据,并不是全然不支持,提供了相应的 API,下面就给大家介绍一下。

一、鸿蒙SDK中的 XML API

在鸿蒙SDK中,可用于 XML 文档处理的 API,主要有两个:

  • @ohos.xml:XML 解析与生成
  • @ohos.convertxml:XML 转换 Javascript

1、@ohos.xml

在该模块,共包含一下几个与XML文档相关的对象:

  • XmlSerializer:用于生成 XML 文档
  • XmlPullParser:用于解析 XML 文档
  • ParseOptions:XML 解析选项
  • ParseInfo:XML 解析信息
  • EventType:XML 标签事件类型

其中用于 XML 解析的接口,自然就是 XmlPullParser 接口,具体而言,就是XmlPullParser.parseXml(option: ParseOptions): void 方法,而 ParseOptions 由如下成员组成:
在这里插入图片描述XML 文档中的数据,并不会由 parseXml 方法返回,而是在 ParseOptions 中传入的三个回调函数中获取:
作为关键的 tagValueCallbackFunction,可用于解析 XML 标签,返回 true 表示向下一层解析,返回 false 表示不再继续解析,可用于读取标签名称,特别的,如标签内的文本不会通过 value 返回,而是当作标签名为空的标签进行解析,以 CSDN 的 RSS 订阅返回的 XML 文档为例,利用该方法解析出来的信息如下:
在这里插入图片描述所以,很鸡肋,想要用这个方法去获取 XML 格式封装的数据,需要费很大的周折。因此,我不建议在鸿蒙应用中,用这种方式去解析 XML 并获取数据。

2、@ohos.convertxml

该模块相当简洁,一共就两个接口:ConvertXML 和 ConvertOptions,而 ConvertXML 下,目前就剩下一个官方还在维护的 fastConvertToJSObject(xml: string, options?: ConvertOptions) : Object 方法,而 ConvertOption 主要用于声明格式转换过程中使用映射关系:
在这里插入图片描述
最终会用指定映射关系,生成一个Javascript 对象,而 Javascript 对象在 ArkTS 中,读取数据就方便了,也因此,我首推大家用这个 API 去实现鸿蒙应用中的 XML 解析功能。

三、XML 解析实践

这里,直接以 CSDN 对外提供的 RSS 订阅为 XML 数据,使用 ConvertXML 接口进行解析实践。

1、源数据结构

首先,看一下 CSDN 的 RSS 订阅链接返回的 XML 数据的结构:
在这里插入图片描述如图所圈,在 channel 标签下的 item 标签封装了具体的文章信息,如文章标题、文章链接和文章简介等,而这也是我们订阅 RSS 所需要的核心数据,所以,就需要将里面的所有 item 标签中的文章信息读取出来。

2、定义映射关系

为了将 XML 数据转换 Javascript 对象数据,需要定一个 ConvertXML.fastConvertToJSObject 方法所需的键值映射关系:

let options: convertxml.ConvertOptions = {
 trim: false,
 declarationKey: "_declaration",
 instructionKey: "_instruction",
 attributesKey: "_attributes",
 textKey: "_text",
 cdataKey: "_cdata",
 doctypeKey: "_doctype",
 commentKey: "_comment",
 parentKey: "_parent",
 typeKey: "_type",
 nameKey: "_name",
 elementsKey: "_elements"
}

3、定义接收对象

ConvertXML.fastConvertToJSObject 方法会将 XML 数据转换成 Javascript 对象,然而, ArkTS 语法现在不允许用 data['key'] 形式去读取对象字段,只能用 object.field 的方式读取,所以,就需要根据 ConvertXML.fastConvertToJSObject 生成的对象数据结构:
在这里插入图片描述去定义一个对应的ArkTS 类:
在这里插入图片描述有了这个 XMLModel,那么就可以直接用语句 const xml: XMLModel = conv.fastConvertToJSObject(strXML, options) as XMLModel; 保存转换结果。

4、获取文章信息

有了 XMLModel 去接受 fastConvertToJSObject 方法的转换结果,从中获取具体的文章信息就容易很多了,同样的,为了方便页面展示或者透传文章信息到其他页面,需要定义相应的 Model:

export class DocModel {
  title: string = "";
  link: string = "";
  author: string = "";
  pubDate: string = "";
  description: string = "";
}

而进一步解析 XMLModel 获取文章信息,则可以通过如下两个方法完成:
在这里插入图片描述在这里插入图片描述

四、总结

鸿蒙应用中使用 XML 格式的数据,关键还是在于将其转换成可直接使用的类对象,而这个转换过程,无需开发者自己实现,鸿蒙SDK中的 ConvertXML 接口早已提供相应能力,开发者只需关心转换之后的 Javascript 对象该如何定义,以及进一步解析后的数据如何封装和使用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

御承扬

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值