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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
|
---
title: content
slug: Web/CSS/content
tags:
- CSS
- CSS カウンター
- CSS プロパティ
- 生成コンテンツ
- Reference
- recipe:css-property
browser-compat: css.properties.content
translation_of: Web/CSS/content
---
{{CSSRef}}
**`content`** は [CSS](/ja/docs/Web/CSS) のプロパティで、ある要素を生成された値で置き換えます。 `content` プロパティを使用して挿入されたオブジェクトは、**無名の[置換要素](/ja/docs/Web/CSS/Replaced_element)** になります。
```css
/* 他の値と組み合わせることができないキーワード */
content: normal;
content: none;
/* <image> 値 */
content: url("http://www.example.com/test.png");
content: linear-gradient(#e66465, #9198e5);
/* 生成コンテンツの代替テキスト、レベル 3 の仕様書で追加 */
content: url("http://www.example.com/test.png") / "This is the alt text";
/* <string> 値 */
content: "prefix";
/* <counter> 値、任意で <list-style-type> */
content: counter(chapter_counter);
content: counter(chapter_counter, upper-roman);
content: counters(section_counter, ".");
content: counters(section_counter, ".", decimal-leading-zero);
/* HTML 属性値にリンクした attr() 値 */
content: attr(value string);
/* 言語や位置に依存したキーワード */
content: open-quote;
content: close-quote;
content: no-open-quote;
content: no-close-quote;
/* normal と none を除き、複数の値が同時に使用可 */
content: open-quote counter(chapter_counter);
/* グローバル値 */
content: inherit;
content: initial;
content: revert;
content: unset;
```
## 構文
### 値
- `none`
- : 擬似要素に適用された場合は、その擬似要素は生成されません。要素に適用された場合は、この値は効果がありません。
- `normal`
- : `::before` および `::after` 擬似要素では `none` として計算されます。
- {{cssxref("<string>")}}
- : 要素の「代替テキスト」を指定します。この値は任意の数のテキスト文字です。ラテン文字以外は Unicode エスケープシーケンスを使用してエンコードする必要があります。例えば、 `\000A9` は著作権記号を表します。
- {{cssxref("<image>")}}
- : {{cssxref("<image>")}} です。 {{cssxref("url()")}} または {{cssxref("<gradient>")}} データ型、または {{cssxref("element()", "element()")}} 関数で定義されるウェブページの一部です。
- {{cssxref("counter()")}}
- : [CSS カウンター](/ja/docs/Web/CSS/CSS_Lists_and_Counters/Using_CSS_counters)の値で、通常は {{cssxref("<counter-reset>")}} および {{cssxref("<counter-increment>")}} プロパティで定義され、計算によって生み出される数値です。 {{cssxref("counter()")}} または {{cssxref("counters()")}} 関数を使用して表示することができます。
{{cssxref("counter()")}} 関数には、 'counter(_名前_)' または 'counter(_名前_, スタイル)' の二つの形式があります。生成されるテキストは、その擬似要素のスコープにおけるその名前の最も内側のカウンターです。{{cssxref("<list-style-type>")}} で指定されたスタイルで整形されます (`decimal` が既定値です)。
{{cssxref("counters()")}} 関数も、 'counters(_名前_, _文字列_)' または 'counters(_名前_, _文字列_, _スタイル_)' の二つの形式があります。生成されるテキストは、その擬似要素のスコープにおけるその名前のすべてのカウンターの値であり、外側から内側に向けて、指定された文字列で区切られます。カウンターは指定されたスタイルで表示されます(`decimal` が既定値です)。
- `attr(x)`
- : 要素の属性の値 `x` を文字列として返します。属性 `x` が存在しない場合は、空文字列が返されます。属性名の大文字と小文字が区別されるかどうかは、文書の言語に依存します。
- `open-quote` | `close-quote`
- : これらの値は {{cssxref("quotes")}} プロパティの対応する文字列に置き換えられます。
- `no-open-quote` | `no-close-quote`
- : 内容はありませんが、引用符の入れ子の階層を増加 (または減少) させます。
## アクセシビリティの考慮
CSS で生成されるコンテンツは、 [DOM](/ja/docs/Web/API/Document_Object_Model/Introduction) には含まれません。そのため、これは[アクセシビリティツリー](/ja/docs/Learn/Accessibility/What_is_accessibility#accessibility_apis)では表現されず、支援技術とブラウザーの組み合わせによってはアナウンスされないことがあります。そのコンテンツがページの目的を理解する上で重要な情報を含んでいるのであれば、メイン文書に含めたほうが適切です。
- [Accessibility support for CSS generated content – Tink](https://tink.uk/accessibility-support-for-css-generated-content/)
- [WCAG の解説、ガイドライン 1.3 – MDN](/ja/docs/Web/Accessibility/Understanding_WCAG/Perceivable#guideline_1.3_%e2%80%94_create_content_that_can_be_presented_in_different_ways)
- [Understanding Success Criterion 1.3.1 | W3C Understanding WCAG 2.0](https://www.w3.org/TR/UNDERSTANDING-WCAG20/content-structure-separation-programmatic.html)
## 公式定義
{{cssinfo}}
## 形式文法
{{csssyntax}}
## 例
<h3 id="Headings_and_quotes">見出しと引用符</h3>
この例では引用部分の周りに引用符を挿入し、見出しの前に "Chapter" の語を追加します。
#### HTML
```html
<h1>5</h1>
<p>According to Sir Tim Berners-Lee,
<q cite="http://www.w3.org/People/Berners-Lee/FAQ.html#Internet">I was
lucky enough to invent the Web at the time when the Internet
already existed - and had for a decade and a half.</q>
We must understand that there is nothing fundamentally wrong
with building on the contributions of others.
</p>
<h1>6</h1>
<p>According to the Mozilla Manifesto,
<q cite="http://www.mozilla.org/en-US/about/manifesto/">Individuals
must have the ability to shape the Internet and
their own experiences on the Internet.</q>
Therefore, we can infer that contributing to the open web
can protect our own individual experiences on it.
</p>
```
#### CSS
```css
q {
color: blue;
}
q::before {
content: open-quote;
}
q::after {
content: close-quote;
}
h1::before {
content: "Chapter "; /* 最後の空白は、追加コンテンツと
残りのコンテンツの間を区切る
ものです */
}
```
#### 結果
<p>{{EmbedLiveSample('Headings_and_quotes', '100%', 200)}}
<h3 id="Image_combined_with_text">テキストと組み合わせる画像</h3>
この例はリンクの前に画像を挿入します。画像が見つからなければ、代わりにテキストを挿入します。
#### HTML
```html
<a href="https://www.mozilla.org/en-US/">Mozilla Home Page</a>
```
#### CSS
```css
a::before {
content: url("https://mozorg.cdn.mozilla.net/media/img/favicon.ico") / " MOZILLA: ";
font: x-small Arial, sans-serif;
color: gray;
}
```
#### 結果
{{EmbedLiveSample('Image_combined_with_text', '100%', 60)}}
<h3 id="Targeting_classes">クラスのターゲッティング</h3>
この例はリストの特定の項目の後に追加のテキストを挿入します。
#### HTML
```html
<h2>Paperback Best Sellers</h2>
<ol>
<li>Political Thriller</li>
<li class="new-entry">Halloween Stories</li>
<li>My Biography</li>
<li class="new-entry">Vampire Romance</li>
</ol>
```
#### CSS
```css
.new-entry::after {
content: " New!"; /* 先頭の空白は、追加コンテンツと
残りのコンテンツの間を区切る
ものです */
color: red;
}
```
#### 結果
{{EmbedLiveSample('Targeting_classes', '100%', 160)}}
<h3 id="Images_and_element_attributes">画像および要素の属性</h3>
この例はそれぞれのリンクの前に画像を挿入し、後に `id` 属性を追加します。
#### HTML
```html
<ul>
<li><a id="moz" href="https://www.mozilla.org/">
Mozilla Home Page</a></li>
<li><a id="mdn" href="https://developer.mozilla.org/">
Mozilla Developer Network</a></li>
</ul>
```
#### CSS
```css
a {
text-decoration: none;
border-bottom: 3px dotted navy;
}
a::after {
content: " (" attr(id) ")";
}
#moz::before {
content: url("https://mozorg.cdn.mozilla.net/media/img/favicon.ico");
}
#mdn::before {
content: url("mdn-favicon16.png");
}
li {
margin: 1em;
}
```
#### 結果
{{EmbedLiveSample('Images_and_element_attributes', '100%', 160)}}
<h3 id="Element_replacement">要素の置き換え</h3>
この例は、要素の内容を画像で置き換えます。要素の内容を {{cssxref("url()")}} または {{cssxref("<image>")}} の値のどちらかで置き換えることができます。 `::before` または `::after` で追加された内容は、要素の中身が置き換えられるときは生成されません。
#### HTML
```html
<div id="replaced">Mozilla</div>
```
#### CSS
```css
#replaced {
content: url("mdn.svg");
}
#replaced::after { /* 要素の置換に対応している場合は表示されない */
content: " (" attr(id) ")";
}
```
#### 結果
{{EmbedLiveSample('Element_replacement', '100%', 200)}}
## 仕様書
{{Specifications}}
## ブラウザーの互換性
{{Compat}}
## 関連情報
- [置換要素](/ja/docs/Web/CSS/Replaced_element)
- {{Cssxref("::after")}}
- {{Cssxref("::before")}}
- {{Cssxref("::marker")}}
- {{Cssxref("quotes")}}
- {{cssxref("url()", "url()")}} 関数
|