blob: 160e564f85345ce5cce362d8e0bb76f7f4562d10 (
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
---
title: <position>
slug: Web/CSS/position_value
tags:
- CSS
- CSS データ型
- データ型
- レイアウト
- リファレンス
- ウェブ
browser-compat: css.types.position
translation_of: Web/CSS/position_value
---
{{CSSRef}}
**`<position>`** (または **`<bg-position>`**) は [CSS](/ja/docs/Web/CSS) の [データ型](/ja/docs/Web/CSS/CSS_Types)で、二次元の座標を表し、要素ボックスからの相対的な位置を示すために用いられます。 {{cssxref("background-position")}} および {{cssxref("offset-anchor")}} で使用されています。
> **Note:** `<position>` 値で記述される最終的な位置は、要素ボックスの中である必要はありません。
## 構文
![](position_type.png)`<position>` データ型は 1 ~ 2 つのキーワードと、任意のオフセットで定義されます。
キーワード値は `center`、 `top`、 `right`、 `bottom`、 `left` です。それぞれのキーワードは要素ボックスの辺または2辺の中心線を表します。使われる場所によって、 `center` は左右の辺の中心か、上下の辺の中心を表します。
オフセット値を指定する場合は、相対的な {{cssxref("<percentage>")}} 値か絶対的な {{cssxref("<length>")}} 値のどちらかで指定することができます。正の数は右または下(適切な方)に向けたオフセットで、負の数は逆方向のオフセットです。
単一のオフセット値のみが指定された場合は X 座標を定義し、もう一方の軸は既定値の `center` に設定されます。
```css
/* 値 1 つの構文 */
keyword /* 水平位置または垂直位置。もう一方の軸は既定値の center になる */
value /* X 座標の位置。 Y 座標は既定値の 50% になる */
/* 値 2 つの構文 */
keyword keyword /* それぞれの方向のキーワード(順不同) */
keyword value /* キーワードで定義された辺からのオフセット */
value keyword /* 水平位置を表す値、垂直位置を表すキーワード */
value value /* それぞれの方向(水平、垂直)の距離の値 */
/* 値 4 つの構文 */
keyword value keyword value /* それぞれの値はその前のキーワードからのオフセット */
```
### 形式文法
```css
[
[ left | center | right ] || [ top | center | bottom ]
|
[ left | center | right | <length> | <percentage> ]
[ top | center | bottom | <length> | <percentage> ]?
|
[ [ left | right ] [ <length> | <percentage> ] ] &&
[ [ top | bottom ] [ <length> | <percentage> ] ]
]
```
> **Note:** {{cssxref("background-position")}} プロパティも3つの値の構文を受け付けます。これは `<position>` を使用する他のプロパティでは許可されません。
## 補間
アニメーション時、座標の横軸と縦軸の値が独立して補間されます。ただし、補間の速度は両方の座標で1つの[タイミング関数](/ja/docs/Web/CSS/easing-function)が用いられるため、座標は直線に移動します。
## 例
### 有効な位置
center
left
center top
right 8.5%
bottom 12vmin right -6px
10% 20%
8rem 14px
### 無効な位置
```plain example-bad
left right
bottom top
10px 15px 20px 15px
```
## 仕様書
{{Specifications}}
## ブラウザーの互換性
{{Compat}}
## 関連情報
- [CSS 値と単位](/ja/docs/Web/CSS/CSS_Values_and_Units)
- [CSS 値と単位の紹介](/ja/docs/Learn/CSS/Building_blocks/Values_and_units)
- {{cssxref("background-position")}}
- {{cssxref("gradient/radial-gradient()", "radial-gradient()")}}
- {{cssxref("gradient/conic-gradient()", "conic-gradient()")}}
|