blob: 094ad5899c2f9f3f5e184521b06fc70934b81182 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
---
title: Document.getElementsByClassName()
slug: Web/API/Document/getElementsByClassName
tags:
- 待翻譯
translation_of: Web/API/Document/getElementsByClassName
---
<p id="Summary">{{APIRef("DOM")}}</p>
<p>針對所有給定的 class 子元素,回傳類似陣列的物件。當呼叫 document 物件時,它會搜尋整個文件,包括根節點在內。你也可以在所有元素呼叫 {{domxref("Element.getElementsByClassName", "getElementsByClassName()")}},那它就只會回傳含有給定 class 的特定根元素的後代元素。</p>
<h2 id="Syntax" name="Syntax">表達式</h2>
<pre class="syntaxbox"><var>var elements</var> = document.getElementsByClassName(<em>names</em>); // or:
<var>var elements</var> = rootElement.getElementsByClassName(<em>names</em>);</pre>
<ul>
<li><var>elements</var> 為符合 class 名稱的 {{ domxref("HTMLCollection") }}。</li>
<li><var>names</var> 為符合 class 名稱的字串;class 名稱可以用空白分隔。</li>
<li>getElementsByClassName 可以被任何不只在 document 的元素呼叫。呼叫這個方法的元素將會成為搜尋 class 的根元素。</li>
</ul>
<h2 id="Examples" name="Examples">範例</h2>
<p>取得所有 class 為 “test” 的元素:</p>
<pre class="brush: js">document.getElementsByClassName('test');</pre>
<p>取得所有 class 為 “test” 和 “red” 的元素:</p>
<pre class="brush: js">document.getElementsByClassName('red test');</pre>
<p>取得所有在 id 為 '“main” 的元素裡 class 為 “test” 的元素:</p>
<pre class="brush: js">document.getElementById('main').getElementsByClassName('test');</pre>
<p>我們也可以藉由傳遞 {{ domxref("HTMLCollection") }} 為 <var>this </var>來使用 <code>Array.prototype</code> 的方法。下面的例子將會找到所有 class 為 “test” 的 div 元素:</p>
<pre class="brush: js">var testElements = document.getElementsByClassName('test');
var testDivs = Array.prototype.filter.call(testElements, function(testElement){
return testElement.nodeName === 'DIV';
});</pre>
<h2 id="取得_class_是_test_的元素">取得 class 是 test 的元素</h2>
<p>這是最常用的操作方法:</p>
<pre><!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<div id="parent-id">
<p>hello word1</p>
<p class="test">hello word2</p>
<p>hello word3</p>
<p>hello word4</p>
</div>
<script>
var parentDOM = document.getElementById("parent-id");
var test=parentDOM.getElementsByClassName("test");//test is not target element
console.log(test);//HTMLCollection[1]
var testTarget=parentDOM.getElementsByClassName("test")[0];//year , this element is target
console.log(testTarget);//<p class="test">hello word2</p>
</script>
</body>
</html></pre>
<h2 id="瀏覽器相容性">瀏覽器相容性</h2>
{{Compat("api.Document.getElementsByClassName")}}
<h2 id="Specification" name="Specification">規範</h2>
<ul>
<li><a href="https://dvcs.w3.org/hg/domcore/raw-file/tip/Overview.html#dom-document-getelementsbyclassname" title="https://dvcs.w3.org/hg/domcore/raw-file/tip/Overview.html#dom-document-getelementsbyclassname"><span class="external">W3C: getElementsByClassName</span></a></li>
</ul>
|