0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

OpenHarmony语言基础类库【@ohos.convertxml】

jf_46214456 来源:jf_46214456 作者:jf_46214456 2024-04-23 21:09 次阅读

@ohos.convertxml (xml转换JavaScript)

本模块提供转换xml文本为JavaScript对象的功能。

说明:

本模块首批接口从API version 8开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

导入模块

import convertxml from '@ohos.convertxml';

ConvertXML

convertToJSObject9+

convertToJSObject(xml: string, options?: ConvertOptions) : Object

转换xml文本为JavaScript对象。

系统能力: SystemCapability.Utils.Lang

参数

参数名类型必填说明
xmlstring传入的xml文本。
options[ConvertOptions]转换选项 , 默认值是ConvertOptions对象 , 由其中各个属性的默认值组成。

返回值:

类型说明
Object处理后返回的JavaScript对象。

错误码:

以下错误码的详细介绍请参见[语言基础类库错误码]

错误码ID错误信息
10200002Invalid xml string.

示例:

try {
    let xml =
        '< ?xml version="1.0" encoding="utf-8"? >' +
        '< note importance="high" logged="true" >' +
        '    < title >Happy< /title >' +
        '    < todo >Work< /todo >' +
        '    < todo >Play< /todo >' +
        '< /note >';
    let conv = new convertxml.ConvertXML()
    let options = {
        trim: false, declarationKey: "_declaration",
        instructionKey: "_instruction", attributesKey: "_attributes",
        textKey: "_text", cdataKey: "_cdata", doctypeKey: "_doctype",
        commentKey: "_comment", parentKey: "_parent", typeKey: "_type",
        nameKey: "_name", elementsKey: "_elements"
    }
    let result = JSON.stringify(conv.convertToJSObject(xml, options));
    console.log(result);
} catch (e) {
    console.log(e.toString());
}
// 输出(宽泛型)
// {"_declaration":{"_attributes":{"version":"1.0","encoding":"utf-8"}},"_elements":[{"_type":"element","_name":"note","_attributes":{"importance":"high","logged":"true"},"_elements":[{"_type":"element","_name":"title","_elements":[{"_type":"text","_text":"Happy"}]},{"_type":"element","_name":"todo","_elements":[{"_type":"text","_text":"Work"}]},{"_type":"element","_name":"todo","_elements":[{"_type":"text","_text":"Play"}]}]}]}

convert(deprecated)

convert(xml: string, options?: ConvertOptions) : Object

转换xml文本为JavaScript对象。

说明:

从API version 8开始支持,从API version 9开始废弃,建议使用[convertToJSObject9+]替代。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
xmlstring传入的xml文本。
options[ConvertOptions]转换选项 , 默认值是ConvertOptions对象 , 由其中各个属性的默认值组成。

返回值:

类型说明
Object处理后返回的JavaScript对象。

示例:

let xml =
    '< ?xml version="1.0" encoding="utf-8"? >' +
    '< note importance="high" logged="true" >' +
    '    < title >Happy< /title >' +
    '    < todo >Work< /todo >' +
    '    < todo >Play< /todo >' +
    '< /note >';
let conv = new convertxml.ConvertXML();
let options = {trim : false, declarationKey:"_declaration",
    instructionKey : "_instruction", attributesKey : "_attributes",
    textKey : "_text", cdataKey:"_cdata", doctypeKey : "_doctype",
    commentKey : "_comment", parentKey : "_parent", typeKey : "_type",
    nameKey : "_name", elementsKey : "_elements"}
let result = JSON.stringify(conv.convert(xml, options));
console.log(result);
// 输出(宽泛型)
// {"_declaration":{"_attributes":{"version":"1.0","encoding":"utf-8"}},"_elements":[{"_type":"element","_name":"note","_attributes":{"importance":"high","logged":"true"},"_elements":[{"_type":"element","_name":"title","_elements":[{"_type":"text","_text":"Happy"}]},{"_type":"element","_name":"todo","_elements":[{"_type":"text","_text":"Work"}]},{"_type":"element","_name":"todo","_elements":[{"_type":"text","_text":"Play"}]}]}]}

ConvertOptions

鸿蒙开发指导文档:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

搜狗高速浏览器截图20240326151547.png

转换选项。

系统能力: SystemCapability.Utils.Lang

名称类型必填说明
trimboolean是否修剪位于文本前后的空白字符。
ignoreDeclarationboolean是否忽略xml写入声明指示,默认false。
ignoreInstructionboolean是否忽略xml的写入处理指令,默认false。
ignoreAttributesboolean是否跨多行打印属性并缩进属性,默认false。
ignoreCommentboolean是否忽略元素的注释信息,默认false。
ignoreCDATAboolean是否忽略元素的CDATA信息,默认false。
ignoreDoctypeboolean是否忽略元素的Doctype信息,默认false。
ignoreTextboolean是否忽略元素的文本信息,默认false。
declarationKeystring用于输出对象中declaration的属性键的名称。
instructionKeystring用于输出对象中instruction的属性键的名称。
attributesKeystring用于输出对象中attributes的属性键的名称。
textKeystring用于输出对象中text的属性键的名称。
cdataKeystring用于输出对象中cdata的属性键的名称
doctypeKeystring用于输出对象中doctype的属性键的名称。
commentKeystring用于输出对象中comment的属性键的名称。
parentKeystring用于输出对象中parent的属性键的名称。
typeKeystring用于输出对象中type的属性键的名称。
nameKeystring用于输出对象中name的属性键的名称。
elementsKeystring用于输出对象中elements的属性键的名称。

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 鸿蒙
    +关注

    关注

    55

    文章

    1651

    浏览量

    42136
  • OpenHarmony
    +关注

    关注

    23

    文章

    3327

    浏览量

    15176
收藏 人收藏

    评论

    相关推荐

    OpenHarmony开源GPUMesa3D适配说明

    本文档主要讲解在OpenHarmony中,Mesa3D的适配方法及原理说明。 环境说明: OHOS版本: 适用3.2-Beta3及以上 内核版本: linux-5.10 硬件环境
    发表于 12-25 11:38

    ArkTS语言基础-解析

    ArkTS语言基础是HarmonyOS系统上为应用开发者提供的常用基础能力,主要包含能力如下图所示。 图1 ArkTS语言基础
    发表于 02-20 16:44

    赶紧收藏!7大400多种组件,鸿蒙三方来了!

    方法https://gitee.com/openharmony-tpc/butterknifeassertj-ohos快速调用其他封装https://gitee.com/openharmon
    发表于 05-07 14:07

    介绍几种OpenHarmony 开源软件设计

    1、鸿蒙开源组件——获取签名或绘图的功能ink-ohos介绍项目名称:ink-ohos所属系列:openharmony 的第三方组件适配移植功能:ink-
    发表于 03-15 13:50

    怎样将buildroot移植到ohos里呢?有哪些步骤

    /buildroot-2021.02.8make menuconfig配置你需要的文件sudo make开始编译编译后记得编译一次ohos这样才打包buildrootohos镜像里面。六、不足1.可能有些工具添加编译后,还需
    发表于 03-17 10:40

    HarmonyOS/OpenHarmony应用开发-Stage模型ArkTS语言AbilityStage

    进行初始化时回调。context接口示例:*附件:HarmonyOSOpenHarmony应用开发-stage模型ArkTS语言AbilityStage.docx
    发表于 04-07 15:16

    HarmonyOS/OpenHarmony应用开发-Stage模型ArkTS语言扩展能力基

    \'@ohos.app.ability.ExtensionAbility\'; 接口示例: *附件:HarmonyOSOpenHarmony应用开发-stage模型ArkTS语言扩展能力基
    发表于 04-26 10:00

    HarmonyOS语言基础开发指南上线啦!

    理和操作数据,并且更适合在JavaScript应用程序中使用。 语言基础提供ConvertXML将XML文本转换为JavaScript
    发表于 10-18 16:36

    OpenHarmony C++公共基础应用案例:HelloWorld

    1、程序简介 该程序是基于OpenHarmony的C++公共基础的简单案例:HelloWorld。 该应用案例已在OpenHarmony凌蒙派-RK3568开发板(即
    发表于 11-22 11:21

    OpenHarmony C++公共基础应用案例:Thread

    OpenHarmony C++公共基础应用案例:Thread 1、程序简介 该程序是基于OpenHarmony的C++公共基础
    发表于 11-22 11:50

    OpenHarmony之NAPI框架介绍

    。 可以看到,NAPI 接口本身是 C++语言实现的,这些接口可以帮助 C++代码创建 JS 变量,或访问 JavaScript 运行环境中的 JS 变量与方法。 OpenHarmony
    发表于 11-23 15:36

    基于openharmony移植的ohos拼图支持库

    项目介绍 项目名称:PuzzleView 所属系列:openharmony的第三方组件适配移植 功能:ohos拼图支持库 项目移植状态:主功能完成,由于ohos暂不支持,所以分享功能暂未实现 调用
    发表于 03-22 11:24 2次下载

    基于openharmony适配移植的Ohos应用程序评价

    项目介绍 项目名称:OhosRateThisApp 所属系列:openharmony的第三方组件适配移植 功能:ohos库显示“为该应用评分”对话框 项目移植状态:主功能完成 调用差异:无 开发版本
    发表于 03-28 10:33 2次下载

    openharmony第三方组件适配移植易于使用的ohos

    项目介绍 项目名称:MaterialScrollBar 所属系列:openharmony的第三方组件适配移植 功能:易于使用的ohos库,可轻松实现滚动跟随效果 项目移植状态:主功能完成 调用差异
    发表于 03-30 10:44 0次下载

    先楫半导体携手OpenHarmony正式发布HPMicro ohos v1.0.0

    各位关注先楫的小伙伴们,基于OpenHarmony 4.0-Release版本和hpm_sdk v1.4.0 版本的 HPMicro ohos v1.0.0 正式发布了。
    的头像 发表于 04-02 10:45 327次阅读
    先楫半导体携手<b class='flag-5'>OpenHarmony</b>正式发布HPMicro <b class='flag-5'>ohos</b> v1.0.0