top
        
        
          
                Baseline
                
                  Widely available
                
                 *
              
        
        
        
          
                
              
                
              
                
              
        
        
      
      This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2015年7月.
* Some parts of this feature may have varying levels of support.
top は CSS のプロパティで、位置指定要素の垂直位置の決定に関与します。位置指定されていない要素には効果はありません。
試してみましょう
top: 0;
top: 4em;
top: 10%;
top: 20px;
<section id="default-example">
  <div class="example-container">
    <div id="example-element">I am absolutely positioned.</div>
    <p>
      As much mud in the streets as if the waters had but newly retired from the
      face of the earth, and it would not be wonderful to meet a Megalosaurus,
      forty feet long or so, waddling like an elephantine lizard up Holborn
      Hill.
    </p>
  </div>
</section>
.example-container {
  border: 0.75em solid;
  padding: 0.75em;
  text-align: left;
  position: relative;
  width: 100%;
  min-height: 200px;
}
#example-element {
  background-color: #264653;
  border: 4px solid #ffb500;
  color: white;
  position: absolute;
  width: 140px;
  height: 60px;
}
top の効果は、要素がどの様に配置されているか(つまり、 position プロパティの値)によって変わります。
- positionが- absoluteまたは- fixedに設定されている場合、- topプロパティは要素の上辺と包含ブロックの上辺との間の距離を指定します。
- positionが- relativeに設定されている場合、- topプロパティは要素の上辺が通常位置から下方へ移動する量を指定します。
- positionが- stickyに設定されている場合、- topプロパティは粘着制約矩形の計算に使用されます。
- positionが- staticに設定されている場合、- topプロパティは効果がありません。
top と bottom の両方が指定されている場合は、 3 つの異なる場合があります。
- positionが- absoluteまたは- fixedに設定されており、- heightが指定されていない(- autoまたは- 100%である)場合、- topおよび- bottomの両方が尊重されます。
- positionが- relativeに設定されているか、- heightが指定されている場合、- topプロパティが優先され、- bottomプロパティは無視されます。
- positionが- stickyに設定されている場合、- topと- bottomの両方の値が考慮されます。つまり、粘着位置指定要素は、要素の位置ボックスがそのブロック内に収まっている限り、これら 2 つのプロパティの値に基づいて、そのブロック内で上下に移動できる可能性があります。
構文
css
/* <length> 値 */
top: 3px;
top: 2.4em;
/* 包含ブロックの高さに対する <percentage> */
top: 10%;
/* キーワード値 */
top: auto;
/* グローバル値 */
top: inherit;
top: initial;
top: revert;
top: revert-layer;
top: unset;
値
- <length>
- 
負、null、または正の <length>で、以下のものを表します。- 絶対位置指定要素の場合は、包含ブロックの上辺までの距離。
- 相対位置指定要素の場合は、通常の位置からの下方向への移動量。
 
- <percentage>
- 
包含ブロックの高さに対する <percentage>です。
- auto
- 
以下のように指定します。 
- inherit
- 
値が親要素(包含ブロックとは限りません)の計算値と同じであることを示すキーワードです。そして、この計算値は <length>,<percentage>, またはautoキーワードと同様に扱われます。
公式定義
形式文法
top =
auto |
<length-percentage> |
<anchor()> |
<anchor-size()>
<length-percentage> =
<length> |
<percentage>
<anchor()> =
anchor( <anchor-name>? &&
<anchor-side> , <length-percentage>? )
<anchor-size()> =
anchor-size( [ <anchor-name> || <anchor-size> ]? , <length-percentage>? )
<anchor-name> =
<dashed-ident>
<anchor-side> =
inside |
outside |
top |
left |
right |
bottom |
start |
end |
self-start |
self-end |
<percentage> |
center
<anchor-size> =
width |
height |
block |
inline |
self-block |
self-inline
例
>位置指定要素を上から 10% に設定
css
body {
  background: beige;
}
div {
  position: absolute;
  top: 10%;
  right: 40%;
  bottom: 20%;
  left: 15%;
  background: gold;
  border: 1px solid blue;
}
html
<div>この内容の寸法は、辺の位置によって決まります。</div>
仕様書
| Specification | 
|---|
| CSS Positioned Layout Module Level 3> # insets> | 
ブラウザーの互換性
Loading…
関連情報
- inset: 関連するすべてのプロパティである- top,- bottom,- left,- rightの一括指定
- 対応する論理的プロパティ: inset-block-start,inset-block-end,inset-inline-start,inset-inline-endおよび一括指定のinset-blockとinset-inline
- position