XForms 是 W3C 2003 年发布的下一代表单标准,以 XML 为基础实现数据模型与 UI 彻底分离,支持结构化提交、原生客户端验证、跨设备复用;虽主流浏览器无原生支持,但在政务、医疗等垂直领域持续应用。

XForms 是 W3C 于 2003 年 10 月正式发布的下一代 Web 表单标准,核心目标是解决传统 HTML 表单在数据结构、验证能力、设备适配和逻辑耦合等方面的局限。它不是 HTML 表单的简单增强,而是以 XML 为基础重构表单的设计范式:把“要收集什么数据”和“怎么展示这些数据”彻底分开。
数据模型与 UI 彻底分离
HTML 表单中, 既定义字段名,又决定渲染方式,数据类型、校验规则、默认值等都得靠 JavaScript 或后端补足。XForms 则明确划分为三层:
- 模型层(Model):用 XML Schema 和 XPath 定义数据结构、约束条件(如邮箱格式、必填项)、计算逻辑(如总价=单价×数量)和提交行为;
- 实例层(Instance):一个内嵌的 XML 文档,实时承载用户输入的数据,所有控件都绑定到该实例的特定节点;
-
视图层(View):使用
、等 XForms 控件,通过 XPath 指向实例中的字段,仅负责呈现,不携带业务含义。
原生支持结构化数据与客户端验证
传统表单提交的是扁平的 name/value 对,服务器必须自行解析和校验。XForms 直接提交结构化的 XML 数据,且验证逻辑写在模型里,例如:
浏览器(或兼容插件)可自动执行类型检查、必填判断、正则匹配等,无需手写 JS。数据以 Unicode 编码,天然支持多语言和特殊字符。
真正跨设备、可访问、可复用
因为数据与表现解耦,同一套 XForms 模型可搭配不同样式表或渲染引擎,在手机、盲文阅读器、语音界面(VoiceXML)甚至 SVG 图形界面中复用。例如移动设备可将 渲染为下拉菜单,而语音系统则转为语音提示+语音识别输入。这种设备无关性使它长期被政府、医疗、表单密集型工作流系统采用。
浏览器支持现状与落地方式
主流浏览器未原生集成 XForms,但有成熟替代路径:
- Firefox 曾通过扩展支持,现多依赖 FormFaces(纯 JS 实现,可将 XForms 转为 HTML+JS 运行);
- 企业级方案如 Orbeon Forms、IBM Forms 提供完整服务端渲染与集成能力;
- 部分现代框架可通过 XML 数据绑定插件模拟 XForms 逻辑,但底层仍依赖 JS 驱动。
它不是已被淘汰的技术,而是在高可靠性、强结构化、多终端协同的垂直场景中持续发挥价值的标准。










