data-属性是HTML5新增的合法自定义属性,HTML4不支持,校验会报错且IE9及更早不支持dataset API;其值均为字符串,需手动解析,不参与SEO和无障碍,慎用于大容量数据。
data- 属性,硬写会被视为非法HTML4 严格遵循 DTD 规范,data- 开头的属性不在标准属性列表中。浏览器虽通常会容忍(不报错、仍解析),但校验工具(如 W3C Validator)会标记为错误,且 document.getElementById("x").dataset 在旧版 IE 中根本不存在——这意味着你无法用 dataset API 读取。
常见错误现象:
document.getElementById("btn").dataset.userId // undefined(IE9 及更早、或 HTML4 doctype 下)
,哪怕写了 data-id="123",也属于“无效标记”
.data() 方法在 HTML4 下可读取,但它不是直接读 DOM 属性,而是内部缓存 + 智能转换(比如把 "true" 转成布尔值),行为与原生 dataset 不一致rel、rev 或自定义非标准属性(如 uid="123"),但后者无法被 dataset 访问dataset 是 HTML5 原生 API,只映射 data- 前缀属性HTML5 明确将 data-* 定义为合法自定义属性,并通过 element.dataset 提供统一访问接口。它自动处理命名转换:连字符转驼峰(data-user-id → userId),且仅响应以 data- 开头的属性。
使用场景:动态绑定 ID、状态标识、埋点参数等轻量元数据,避免污染全局变量或额外 DOM 查找。
data- 后必须至少跟一个字符(data- 单独写无效)data-a--b)会被转成 aB(只保留首个连字符后首字母大写,其余连字符被忽略)el.dataset.foo = "bar",DOM 中会自动同步生成 data-foo="bar";但直接改 el.setAttribute("data-foo", "baz"),dataset.foo 也会实时更新JSON.parse()(如果存的是 JSON 字符串)data- 属性没有独立存储机制,它就是 DOM 元素上的普通字符串属性,和 id、class 一样走同一套内存管理。所谓“存储方式不同”是误解——HTML4 不让写,HTML5 允许写且提供 API 读,但底层没变。
data- 值过大(如存 1MB JSON 字符串)会导致 DOM 节点体积膨胀,影响序列化(innerHTML)、克隆(cloneNode)和垃圾回收速度dataset 不比直接 getAttribute/setAttribute 快;现代浏览器对两者做了类似优化,差异可忽略data- 属性,它们不参与语义暴露,也不被搜索引擎索引dataset,但不支持动态添加的 data- 属性反射IE11 实现有缺陷:若元素初始 HTML 中没有 data- 属性,后续用 setAttribute("data-x", "y") 添加,dataset.x 在 IE11 中仍为 undefined,必须刷新整个属性映射(如先读一次 getAttribute 再访问 dataset)才能生效。
el.setAttribute("data-id", "456");
if (el.dataset && !el.dataset.id) {
// IE11 fallback
el.dataset.id = el.getAttribute("data-id");
}
data- 当数据库使;它适合传几个字段 ID 或开关标志,真要存结构化数据,还是走 JS 对象或 Map 更靠谱。最常被忽略的是 IE11 的反射延迟,一上线就发现按钮点不动,查半天才发现是 dataset 没更新。