--- title: Document.getElementsByName() slug: Web/API/Document/getElementsByName tags: - API - DOM - Document - HTML - Method translation_of: Web/API/Document/getElementsByName ---
根据给定的{{domxref("element.name","name")}} 返回一个在 (X)HTML document的节点列表集合。
elements = document.getElementsByName(name)
elements
是一个实时更新的 {{domxref("NodeList")}} 集合。当文档中有同一个name属性的元素被添加或移除时,这个集合会自动更新。name
是元素的 name
属性的值。<!DOCTYPE html> <html lang="en"> <head> ... </head> <body> <form name="up"><input type="text"></form> <div name="down"><input type="text"></div> <script> var up_forms = document.getElementsByName("up"); console.log(up_forms[0].tagName); // returns "FORM" </script> </body> </html>
{{domxref("element.name","name")}} 属性只有在(X)HTML文档中可用。
该方法返回一个live的 {{domxref("NodeList")}} 集合,这个集合包含 {{domxref("element.name","name")}} 属性为指定值的所有元素,例如{{htmlelement("meta")}} 、{{htmlelement("object")}},甚至那些不支持 {{domxref("element.name","name")}} 属性但是添加了 {{domxref("element.name","name")}} 自定义属性的元素也包含其中。
getElementsByName 在不同的浏览器其中工作方式不同。在IE和Opera中, getElementsByName() 方法还会返回那些 {{domxref("element.id","id")}} 为指定值的元素。所以你要小心使用该方法,最好不要为元素的 {{domxref("element.name","name")}} 和 {{domxref("element.id","id")}} 赋予相同的值。
IE 和 Edge 都返回一个 {{domxref("HTMLCollection")}}, 而不是{{domxref("NodeList")}} 。
Specification | Status | Comment |
---|---|---|
{{SpecName('HTML WHATWG', '#dom-document-getelementsbyname', "Document.getElementsByName()")}} | {{ Spec2('HTML WHATWG') }} | |
{{SpecName("DOM2 HTML", "html.html#ID-71555259", "Document.getElementsByName()")}} | {{Spec2("DOM2 HTML")}} | Initial definition |
此页面上的兼容性表由结构化数据生成。 如果您想为数据做出贡献,请查看 https://github.com/mdn/browser-compat-data 并向我们发送 pull 请求。
{{Compat("api.Document.getElementsByName")}}
id
返回对元素的引用'div.myclass'