diff options
-rw-r--r-- | files/ja/web/api/element/queryselector/index.md | 247 |
1 files changed, 161 insertions, 86 deletions
diff --git a/files/ja/web/api/element/queryselector/index.md b/files/ja/web/api/element/queryselector/index.md index 1aec9dde2d..3a058d90ac 100644 --- a/files/ja/web/api/element/queryselector/index.md +++ b/files/ja/web/api/element/queryselector/index.md @@ -1,91 +1,166 @@ --- title: Element.querySelector() slug: Web/API/Element/querySelector +tags: + - API + - CSS + - CSS セレクター + - DOM + - Element + - 要素 + - Finding Elements + - Locating Elements + - メソッド + - リファレンス + - Searching Elements + - Selecting Elements + - セレクター + - querySelector +browser-compat: api.Element.querySelector translation_of: Web/API/Element/querySelector --- -<div>{{APIRef}}</div> - -<p>対象要素の子孫の内、引数に指定したCSSセレクタにマッチする最初の要素を返します。</p> - -<h2 id="Syntax" name="Syntax">構文</h2> - -<pre class="syntaxbox"><var>element</var> = baseElement.querySelector(<em>selector</em>s); -</pre> - -<ul> - <li><code>element</code>と<code>baseElement</code>は{{domxref("element")}}オブジェクトを表します。</li> - <li><code>selectors</code>はマッチさせたい1つ以上の<a href="/ja/docs/Web/Guide/CSS/Getting_Started/Selectors">セレクタ</a>を表します。</li> -</ul> - -<h2 id="Example" name="Example">例</h2> - -<p>次の例では、type属性を持たないか、<span style="font-family: Consolas, Monaco, 'Andale Mono', monospace;"><code>text/css</code>を<code>type</code>属性として持つ、ドキュメントボディーの中で</span>最初の<code style="font-style: normal;">style</code>要素が返却されます。</p> - -<pre class="brush:js">var el = document.body.querySelector("style[type='text/css'], style:not([type])"); -</pre> - -<h2 id="Notes" name="Notes">注記</h2> - -<p>マッチする要素が無い場合は<code>nullを返します</code>。その他の場合は、最初にマッチした要素を返します。</p> - -<p>指定されたセレクタが不正である場合、例外「<code>SYNTAX_ERR</code>」がスローされます。</p> - -<p>Throws a <code>SYNTAX_ERR</code> exception if the specified group of selectors is invalid.</p> - -<p><span style="font-family: Courier New;"><span>querySelector()</span></span>はWebApps API仕様で定義されました。</p> - -<p><code>querySelector</code>に渡す文字列はCSSの文法に則る必要があります。{{domxref("document.querySelector")}}で実例を見て下さい。</p> - -<h2 id="ブラウザ実装状況">ブラウザ実装状況</h2> - -<table class="standard-table"> - <tbody> - <tr> - <th>Browser</th> - <th>Support</th> - <th>Notes</th> - </tr> - <tr> - <td>Internet Explorer</td> - <td>8</td> - <td>CSS 2.1 selectors only (IE8)</td> - </tr> - <tr> - <td>Firefox (Gecko)</td> - <td><strong>3.5</strong> (1.9.1)</td> - <td> </td> - </tr> - <tr> - <td>Opera</td> - <td>10</td> - <td> </td> - </tr> - <tr> - <td>Chrome</td> - <td>1</td> - <td> </td> - </tr> - <tr> - <td>Safari (webkit)</td> - <td>3.2 (525.3)</td> - <td><a class="link-https" href="https://bugs.webkit.org/show_bug.cgi?id=16587">webk.it/16587</a></td> - </tr> - </tbody> -</table> - -<h2 id="Specification" name="Specification">仕様書</h2> - -<ul> - <li>{{spec("http://www.w3.org/TR/selectors-api/","Selectors API Level 1","rec")}}</li> - <li>{{spec("http://www.w3.org/TR/selectors-api2/","Selectors API Level 2","wd")}}</li> - <li>{{spec("http://dev.w3.org/2006/webapi/selectors-api2/","Selectors API Level 2","ed")}}</li> -</ul> - -<h2 id="See_also" name="See_also">関連情報</h2> - -<ul> - <li><a dir="ltr" href="/ja/docs/DOM/Element.querySelectorAll"><code>element.querySelectorAll</code></a></li> - <li><a href="/ja/docs/DOM/Document.querySelector"><code>document.querySelector</code></a></li> - <li><a href="/ja/docs/DOM/Document.querySelectorAll"><code>document.querySelectorAll</code></a></li> - <li><a href="/ja/docs/Code_snippets/QuerySelector">querySelectorのコードスニペット</a></li> -</ul> +{{APIRef("DOM")}} + +**`querySelector()`** は {{domxref("Element")}} インターフェイスのメソッドで、呼び出された要素の子孫要素の中で、指定されたセレクター群に一致する最初の要素を返します。 + +## 構文 + +```js +element = baseElement.querySelector(selectors); +``` + +### 引数 + +- `selectors` + - : その要素 ({{domxref("Element")}}) の子孫要素と照合する[セレクター](/ja/docs/Learn/CSS/Building_blocks/Selectors)群です。これは有効な CSS 構文でなければならず、そうでない場合は `SyntaxError` 例外が発生します。このセレクター群に一致する最初の要素が返されます。 + +### 返値 + +`baseElement` の子孫要素のうち、 `selectors` で指定されたセレクター群に一致するものを返します。照合の際には、 `baseElement` とその子孫を含む要素群の外にあるものも含めて、要素の階層全体を考慮します。言い換えると、 `selectors` はまず `baseElement` ではなく、文書全体に適用され、候補となる要素の初期リストが生成されます。その結果得られた要素が、 `baseElement` の子孫であるかどうかが調べられます。それらの残りの要素のうち、最初に一致したものが `querySelector()` メソッドによって返されます。 + +一致するものが見つからなかったら、返値は `null` になります。 + +### 例外 + +- `SyntaxError` + - : 指定された `selectors` が無効であった場合。 + +## 例 + +いくつかの例を検討してみましょう。 + +### 属性に特定の値を持つ特定の要素を探す + +この最初の例では、 HTML 文書の本文内で type 属性がないか、 type 属性が "text/css" である要素のうち最初のものを返します。 + +```js +var el = document.body.querySelector("style[type='text/css'], style:not([type])"); +``` + +### :scope 擬似クラスを使用して直接の子を取得 + +この例では {{cssxref(":scope")}} 擬似クラスを使用して、 `parentElement` 要素の直接の子を取得します。 + +#### HTML + +```html +<div> + <h6>ページタイトル</h6> + <div id="parent"> + <span>愛は情け深い。</span> + <span> + <span>愛は忍耐強い。</span> + </span> + <span> + <span>愛は見返りを求めない。</span> + </span> + </div> +</div> +``` + +#### CSS + +```css + span { + display:block; + margin-bottom: 5px; + } + .red span { + background-color: red; + padding:5px; + } +``` + +#### JavaScript + +```js + const parentElement = document.querySelector('#parent'); + let allChildren = parentElement.querySelectorAll(":scope > span"); + allChildren.forEach(item => item.classList.add("red")); +``` + +#### 結果 + +{{ EmbedLiveSample('Get_direct_descendants_using_the_scope_pseudo-class', 600, 160) }} + +### 全体の階層数 + +この例では、 `selectors` を適用する際に、文書全体の階層を考慮することを示しています。そのため、位置を照合する際には、指定した `baseElement` 以外のレベルも考慮されることになります。 + +#### HTML + +```html +<div> + <h5>オリジナルコンテンツ</h5> + <p> + 内部の段落 + <span>内部の span</span> + 内部の段落 + </p> +</div> +<div> + <h5>出力</h5> + <div id="output"></div> +</div> +``` + +#### JavaScript + +```js +var baseElement = document.querySelector("p"); +document.getElementById("output").innerHTML = + (baseElement.querySelector("div span").innerHTML); +``` + +#### 結果 + +結果は次のようになります。 + +{{ EmbedLiveSample('The_entire_hierarchy_counts', 600, 160) }} + +`"div span"` セレクターは、 `baseElement` の子ノードが {{HTMLElement("div")}} 要素を含んでいなくても、 {{HTMLElement("span")}} 要素に一致することに注目してください(これはまだ指定したセレクターに含まれています)。 + +### それ以外の例 + +`selectors` の適切な書式について、その他の例は {{domxref("Document.querySelector()")}} を参照してください。 + +## 仕様書 + +{{Specifications}} + +## ブラウザーの互換性 + +{{Compat}} + +## 関連情報 + +- [セレクターを使用した DOM 要素の特定](/ja/docs/Web/API/Document_object_model/Locating_DOM_elements_using_selectors) +- CSS ガイドの[属性セレクター](/ja/docs/Web/CSS/Attribute_selectors) +- MDN 学習領域の[属性セレクター](/ja/docs/Learn/CSS/Building_blocks/Selectors/Attribute_selectors) +- {{domxref("Element.querySelectorAll()")}} +- {{domxref("Document.querySelector()")}} および + {{domxref("Document.querySelectorAll()")}} +- {{domxref("DocumentFragment.querySelector()")}} および + {{domxref("DocumentFragment.querySelectorAll()")}} +- セレクターを取る他のメソッドOther: {{domxref("element.closest()")}} および + {{domxref("element.matches()")}}. |