JavaScript怎么把JSON数据转换成XML字符串

JavaScript无内置JSON转XML方法,需手动递归实现或使用fast-xml-parser等库;手动方式适用于简单结构,库方案支持属性、CDATA、命名空间等完整特性。

JavaScript本身没有内置方法直接把JSON转成XML字符串,但可以通过编写逻辑或借助轻量函数实现。核心思路是递归遍历JSON对象,按XML规则拼接标签和内容。下面提供几种实用方式。

手动实现基础转换(适合简单结构)

适用于扁平对象或单层嵌套,不涉及数组、属性、命名空间等复杂情况:

  • 根节点名需手动指定,比如...
  • 每个键转为子标签名,值转为标签内容;若值为对象,递归生成子树
  • 字符串、数字、布尔值直接作为文本内容;nullundefined可转为空标签或跳过

示例函数:

function jsonToXml(obj, rootName = 'root') {
  const wrap = (key, val) => {
    if (val === null || val === undefined) return `<${key}>`;
    if (typeof val === 'object' && !Array.isArray(val)) {
      const inner = Object.entries(val)
        .map(([k, v]) => wrap(k, v))
        .join('');
      return `<${key}>${inner}`;
    }
    return `<${key}>${String(val)}`;
  };
  return `<${rootName}>${wrap(rootName, obj)}`;
}
// 使用:
// jsonToXml({ name: "Alice", age: 30 }) 
// → "Alice30"

处理数组和同名多节点(更贴近真实XML)

XML中常见多个同级元素(如...多次出现),而JSON数组需显式展开:

  • 遇到数组时,对每个元素调用递归,并统一用“item”或自定义标签名包裹
  • 可约定:若键名以List结尾(如usersList),自动拆解为多个节点
  • 避免生成xxx0>这类非法标签名,需校验并修正键名(如转为

使用成熟库(推荐用于生产环境)

如需健壮性、支持CDATA、属性、注释、格式化缩进等,建议用现成库:

  • fast-xml-parser:轻量、无依赖,支持JSON→XML双向转换,可配置是否忽略空值、是否加空格等
  • xmlbuilder2:链式API,适合构建复杂XML,先建结构再导出字符串
  • 安装与简用:npm install fast-xml-parser,然后
const { XMLBuilder } = require('fast-xml-parser');
const builder = new XMLBuilder({ ignoreAttributes: false });
const xmlStr = builder.build({ root: { name: "Bob", score: 95 } });
// → "Bob95"

注意事项和常见坑

转换不是一一映射,需提前明确规则:

  • XML标签名不能含空格、冒号(除非命名空间)、尖括号、斜杠等,JSON键需清洗(如first-namefirstNamefirst_name
  • XML区分大小写,JSON键也需保持一致大小写习惯
  • 纯数组(如[1,2,3])没有键名,必须指定包装标签,否则无法生成合法XML
  • 如果后端要求严格DTD或XSD校验,还需补全声明、命名空间、属性等,仅靠结构转换不够

基本上就这些。简单场景手写够用,复杂或长期维护项目建议选一个可靠库,省去边界问题排查时间。