aboutsummaryrefslogtreecommitdiff
path: root/files/ja/web/css/replaced_element/index.html
blob: 0f5d5526fceaf00530d5bda52855d62efc5f6dba (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
---
title: 置換要素
slug: Web/CSS/Replaced_element
tags:
  - CSS
  - Reference
  - 置換要素
  - 配置
translation_of: Web/CSS/Replaced_element
---
<div>{{CSSRef}}</div>

<p><span class="seoSummary"><a href="/ja/docs/Web/CSS">CSS</a> において、<strong>置換要素</strong>は CSS のスコープの外で表現される要素です。 CSS の整形モデルとは独立して表現される外部オブジェクトです。</span></p>

<p>もっと簡単な言葉で言い換えれば、コンテンツが現在の文書のスタイルに影響されない要素です。置換要素の位置は CSS を使用して変更することができますが、置換要素自身のコンテンツは違います。 {{HTMLElement("iframe")}} のような一部の置換要素では、独自のスタイルシートを持つことができますが、親文書のスタイルは継承されません。</p>

<p>CSS が置換要素において影響できることは、要素のボックス内におけるコンテンツの位置の制御に対応するプロパティがあることだけです。詳しい情報は{{anch("Controlling object position within the content box", "コンテンツボックス内のオブジェクト位置の制御")}}をご覧ください。</p>

<h2 id="Replaced_elements" name="Replaced_elements">置換要素</h2>

<p>一般的な置換要素は以下の通りです。</p>

<ul>
 <li>{{HTMLElement("iframe")}}</li>
 <li>{{HTMLElement("video")}}</li>
 <li>{{HTMLElement("embed")}}</li>
 <li>{{HTMLElement("img")}}</li>
</ul>

<p>一部の要素は、特定の場合に限って置換要素として扱われます。</p>

<ul>
 <li>{{HTMLElement("option")}}</li>
 <li>{{HTMLElement("audio")}}</li>
 <li>{{HTMLElement("canvas")}}</li>
 <li>{{HTMLElement("object")}}</li>
 <li>{{HTMLElement("applet")}}</li>
</ul>

<p>HTML 仕様書では {{HTMLElement("input")}} 要素も置換要素になることがあるとしており、これは <code>"image"</code> 型の {{HTMLElement("input")}} 要素が {{HTMLElement("img")}} と同様に置換要素であるためです。しかし、他のフォームコントロールは、他の型の {{HTMLElement("input")}} 要素も含め、明示的に非置換要素として挙げられています (仕様書では、プラットフォームに依存した既定のレンダリングを「ウィジェット」という用語で記述しています)。</p>

<p>CSS の {{cssxref("content")}} プロパティを使用して挿入されるオブジェクトは<em>無名置換要素</em>です。 HTML のマークアップには存在しないので、「無名」です。</p>

<h2 id="Using_CSS_with_replaced_elements" name="Using_CSS_with_replaced_elements">置換要素における CSS の使用</h2>

<p>CSS はマージンの計算時や一部の <code>auto</code> 値の時など場合によって、特別に置換要素を扱います。</p>

<p>なお、一部の置換要素は、すべてではありませんが、 {{cssxref("vertical-align")}} のように一部の CSS プロパティで使用される固有の寸法やベースラインの定義を持っていることがあります。置換要素のみが固有の寸法を持つことがあります。</p>

<h3 id="Controlling_object_position_within_the_content_box" name="Controlling_object_position_within_the_content_box">コンテンツボックス内のオブジェクト位置の制御</h3>

<p>置換要素内に含まれたオブジェクトが要素のボックスエリア内で、どのように配置されるかを指定するために、特定の CSS プロパティを使用することができます。これらは {{SpecName("CSS3 Images")}} 及び {{SpecName("CSS4 Images")}} 仕様書で定義されています。</p>

<dl>
 <dt>{{cssxref("object-fit")}}</dt>
 <dd>置換要素の中身のオブジェクトがどのように要素の内包ボックスに合わせられるかを指定します。</dd>
 <dt>{{cssxref("object-position")}}</dt>
 <dd>要素のボックス内で置換要素の中身のオブジェクトが配置される位置を指定します。</dd>
</dl>

<h2 id="See_also" name="See_also">関連情報</h2>

<ul>
 <li><a href="https://html.spec.whatwg.org/multipage/rendering.html#replaced-elements">HTML 仕様書</a></li>
 <li>{{CSS_key_concepts()}}</li>
</ul>