Element:setAttribute() 方法
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Element
接口的 setAttribute()
方法用于设置指定元素上的某个属性值。如果属性已经存在,则更新该值;否则,使用指定的名称和值添加一个新的属性。
要获取某个属性当前的值,请使用 getAttribute()
;要删除某个属性,请使用 removeAttribute()
。
如果你想要在添加时使用 Attr
节点(例如,从另一个元素克隆),你可以改用 setAttributeNode()
方法。
语法
setAttribute(name, value)
参数
name
-
一个用于指定要设置的属性的名称的字符串。当在 HTML 文档中的 HTML 元素上调用
setAttribute()
方法时,该方法会将其属性名称自动转换为全小写形式。 value
-
一个包含要赋给属性的值的字符串。任何指定的非字符串值都会自动转换为字符串。
对于布尔属性,只要它们出现在元素中,就会被视为是 true
。你应该将 value
设置为空字符串(""
)或属性的名称(不带前导或尾随空格)。请参阅下面的示例以获得实际演示。
由于指定的值(value
)会被转换为字符串,所以指定 null
不一定能达到你预期的效果。请将属性的值设置为字符串 "null"
,而不是删除属性或将其值设置为 null
。如果要删除属性,请调用 removeAttribute()
。
返回值
无(undefined
)。
异常
InvalidCharacterError
DOMException
-
如果
name
值不是有效的 XML 名称,则抛出此异常;例如,它以数字、连字符或句点开头,或包含除字母数字字符、下划线、连字符或句点之外的字符。
示例
在下面的示例中,setAttribute()
被用于设置 <button>
上的属性。
HTML
<button>你好,世界</button>
JavaScript
const button = document.querySelector("button");
button.setAttribute("name", "helloButton");
button.setAttribute("disabled", "");
这说明了两件事:
规范
Specification |
---|
DOM Standard # ref-for-dom-element-setattribute① |
浏览器兼容性
BCD tables only load in the browser