XSLT 3.0生成JSON的核心是使用xsl:output method="json"配合map{}和array{}构造数据结构,由处理器自动序列化为标准JSON;需声明version="3.0"、引入map/array命名空间,并确保使用Saxon等支持XSLT 3.0的处理器。

用XSLT 3.0生成JSON输出的核心是利用内置的 json-to-xml() 和 xml-to-json() 函数,但更常用、更直接的方式是:把XML数据结构映射为符合JSON语义的XML格式(即“JSONML”或“XPath 3.1 JSON XML representation”),再用 xsl:output method="json" 触发序列化器自动转成标准JSON字符串。
确保使用XSLT 3.0处理器并声明正确版本
必须使用支持XSLT 3.0的处理器(如 Saxon HE/PE/EE 9.8+、BaseX 9.6+ 或 eXist-db 5.3+)。样式表开头需显式声明版本,并启用JSON输出支持:
- 某些处理器(如Saxon)要求添加 xmlns:map="http://www.w3.org/2005/xpath-functions/map" 和 xmlns:array="http://www.w3.org/2005/xpath-functions/array" 才能使用 map/array 构造函数
- —— 这行必不可少,它告诉处理器最终输出应为合法JSON
用 map{} 和 array{} 构造JSON结构
XSLT 3.0 提供原生函数式数据类型:map(对应JSON对象)和 array(对应JSON数组)。它们可嵌套,且会被 xsl:output method="json" 自动序列化为标准JSON:
- 在模板中直接返回该变量:
- 输出结果为:{"name":"Alice","age":30,"hobbies":["reading","cycling"]}
从XML输入动态构建JSON
常见需求是将XML文档(如订单、用户列表)转为JSON。关键是把节点逻辑映射为 map/array 结构:
- 对每个
元素,用 map{...} 构造对象;用 array{$users/user ! map{...}} 包裹全部 - 注意类型转换:XML文本节点默认是字符串,数值需显式 cast(如 xs:integer(@id)),布尔值用 xs:boolean(@active)
- 空元素或缺失属性可用 ?default 操作符提供 fallback,避免 null 键异常
处理特殊字符与编码
JSON序列化器会自动转义双引号、反斜杠、控制字符等,无需手动处理。但需注意:
- 确保源XML本身编码为UTF-8(推荐在 中声明)
- 中文、emoji 等Unicode字符可直接放入 map value,Saxon会正确编码为UTF-8 JSON字节流
- 若输出到文件, 可显式指定(多数情况下默认即UTF-8)










