ActiveXObject 是 IE6–IE10 中创建 COM XML 解析器(如 MSXML2.DOMDocument)的接口,现代浏览器已弃用;需按版本降级尝试、加 try/catch 和 parseError 校验,推荐封装 createXmlDom() 函数。

ActiveXObject 是 IE(特别是 IE6–IE10)中用于创建 COM 对象的 JavaScript 接口,处理 XML 时常用它来实例化 Microsoft.XMLDOM 或 MSXML2.DOMDocument 等 XML 解析器。现代 浏览器 已完全弃用 ActiveXObject,因此该方式仅适用于旧版 IE 兼容场景。
创建 XML DOM 对象
在 IE 中加载或解析 XML,需先创建支持 XML 的 ActiveXObject 实例。推荐优先尝试较新版本(如 MSXML2),再降级兼容:
-
new ActiveXObject("MSXML2.DOMDocument.6.0")—— 最新稳定版(MSXML 6.0),推荐首选 -
new ActiveXObject("MSXML2.DOMDocument.3.0")—— 广泛兼容(MSXML 3.0),多数 IE6+ 支持 -
new ActiveXObject("Microsoft.XMLDOM")—— 最老版本,仅作兜底(如 IE5.5)
加载 XML 字符串或文件
创建对象后,通过 loadXML() 解析字符串,或 load() 加载外部 XML 文件:
- 解析字符串:
xmlDoc.loadXML("<root><item>hello</item></root>"); - 加载远程文件:
xmlDoc.async = false; xmlDoc.load("data.xml");(注意:同步加载更简单,但会阻塞页面;异步需监听onreadystatechange) - 检查是否加载成功:
if (xmlDoc.parseError.errorCode !== 0) {console.log(xmlDoc.parseError.reason); }
查询和操作 XML 节点
使用标准 DOM 方法(类似现代浏览器),但注意 IE 下部分方法大小写敏感或行为略有差异:
立即学习“Java 免费学习笔记(深入)”;
- 获取节点:
xmlDoc.getElementsByTagName("item")、xmlDoc.selectSingleNode("//item")(支持 XPath) - 设置属性:
node.setAttribute("id", "123") - 读取文本:
node.text(IE 特有,非标准;也可用node.firstChild.nodeValue) - 序列化回字符串:
xmlDoc.xml(IE 特有属性,返回格式化 / 未格式化的 XML 字符串)
兼容性与错误处理建议
因 ActiveXObject 可能被禁用(如 IE 安全策略设为“高”)、版本缺失或脚本错误,务必加 try/catch 和 fallback 判断:
- 用
typeof ActiveXObject !== "undefined"初步判断是否支持 - 逐个尝试不同 ProgID,并捕获异常:
try {xmlDoc = new ActiveXObject(progId); } catch(e) {continue;} - 加载后检查
xmlDoc.readyState === 4 && xmlDoc.parseError.errorCode === 0再继续处理
基本上就这些。ActiveXObject 处理 XML 在 IE 里不算复杂,但容易忽略版本兼容和错误校验,实际项目中建议封装一个健壮的 createXmlDom() 工厂函数统一处理。






























