JavaScript无内置JSON转XML方法,需手动递归实现或使用fast-xml-parser等库;手动方式适用于简单结构,库方案支持属性、CDATA、命名空间等完整特性。
JavaScript本身没有内置方法直接把JSON转成XML字符串,但可以通过编写逻辑或借助轻量函数实现。核心思路是递归遍历JSON对象,按XML规则拼接标签和内容。下面提供几种实用方式。
手动实现基础转换(适合简单结构)
适用于扁平对象或单层嵌套,不涉及数组、属性、命名空间等复杂情况:
- 根节点名需手动指定,比如
... - 每个键转为子标签名,值转为标签内容;若值为对象,递归生成子树
- 字符串、数字、布尔值直接作为文本内容;
null和undefined可转为空标签或跳过
示例函数:
function jsonToXml(obj, rootName = 'root') {
const wrap = (key, val) => {
if (val === null || val === undefined) return `<${key}>${key}>`;
if (typeof val === 'object' && !Array.isArray(val)) {
const inner = Object.entries(val)
.map(([k, v]) => wrap(k, v))
.join('');
return `<${key}>${inner}${key}>`;
}
return `<${key}>${String(val)}${key}>`;
};
return `<${rootName}>${wrap(rootName, obj)}${rootName}>`;
}
// 使用:
// jsonToXml({ name: "Alice", age: 30 })
// → "Alice 30 "
处理数组和同名多节点(更贴近真实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 } });
// → "Bob 95 "
注意事项和常见坑
转换不是一一映射,需提前明确规则:
- XML标签名不能含空格、冒号(除非命名空间)、尖括号、斜杠等,JSON键需清洗(如
first-name→firstName或first_name) - XML区分大小写,JSON键也需保持一致大小写习惯
- 纯数组(如
[1,2,3])没有键名,必须指定包装标签,否则无法生成合法XML - 如果后端要求严格DTD或XSD校验,还需补全声明、命名空间、属性等,仅靠结构转换不够
基本上就这些。简单场景手写够用,复杂或长期维护项目建议选一个可靠库,省去边界问题排查时间。








