aboutsummaryrefslogtreecommitdiff
path: root/files/zh-cn/web/css/replaced_element/index.html
blob: e8909dcccfd552939d0708ebe02cc5eb7700c3d6 (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
---
title: 可替换元素
slug: Web/CSS/Replaced_element
tags:
  - CSS
  - 参考
translation_of: Web/CSS/Replaced_element
---
<div>{{CSSRef()}}</div>

<p><span class="seoSummary"><a href="/zh-CN/docs/Web/CSS">CSS</a> 中,<strong>可替换元素</strong><strong>replaced element</strong>)的展现效果不是由 CSS 来控制的。这些元素是一种外部对象,它们外观的渲染,是独立于 CSS 的。</span></p>

<p>简单来说,它们的内容不受当前文档的样式的影响。CSS 可以影响可替换元素的位置,但不会影响到可替换元素自身的内容。某些可替换元素,例如 {{HTMLElement("iframe")}} 元素,可能具有自己的样式表,但它们不会继承父文档的样式。</p>

<p>CSS 能对可替换元素产生的唯一影响在于,部分属性支持控制元素内容在其框中的位置或定位方式。有关详细信息,请参阅本文下面的{{anch("控制内容框中的对象位置")}}</p>

<h2 id="可替换元素">可替换元素</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")}} 元素,被明确地列为非可替换元素(non-replaced elements)。该规范用术语小挂件(Widgets)来描述它们默认的限定平台的渲染行为。</p>

<p>用 CSS {{cssxref("content")}} 属性插入的对象是匿名的可替换元素。它们并不存在于 HTML 标记中,因此是“匿名的”。</p>

<h2 id="CSS_与可替换元素">CSS 与可替换元素</h2>

<p>CSS 在某些情况下会对可替换元素做一些特殊处理,比如计算外边距({{cssxref("margin")}})和一些 <code>auto</code> 的具体值。</p>

<p>需要注意的是,一部分(并非全部)可替换元素,其本身具有的尺寸和基线(baseline)会被一些 CSS 属性用到,加入计算之中,例如 {{cssxref("vertical-align")}}。只有可替换元素才能具有这种自带值。</p>

<h3 id="控制内容框中的对象位置">控制内容框中的对象位置</h3>

<p>某些CSS属性可用于指定 可替换元素中包含的内容对象 在该元素的盒区域内的位置或定位方式。这些属性的具体定义可以在 {{SpecName("CSS3 Images")}}{{SpecName("CSS4 Images")}} 规范中找到:</p>

<dl>
 <dt>{{cssxref("object-fit")}}</dt>
 <dd>指定可替换元素的内容对象在元素盒区域中的填充方式。(有些类似于 {{cssxref("background-size")}}</dd>
 <dt>{{cssxref("object-position")}}</dt>
 <dd>指定可替换元素的内容对象在元素盒区域中的位置。(类似于 {{cssxref("background-position")}}</dd>
</dl>

<h2 id="参见">参见</h2>

<ul>
 <li>可替换元素的 <a href="https://html.spec.whatwg.org/multipage/rendering.html#replaced-elements">HTML 规范</a></li>
 <li>{{CSS_key_concepts()}}</li>
</ul>