1. 開発者向けのウェブ技術
  2. CSS
  3. リファレンス
  4. プロパティ
  5. margin-block

このページはコミュニティーの尽力で英語から翻訳されました。MDN Web Docs コミュニティーについてもっと知り、仲間になるにはこちらから。

View in English Always switch to English

margin-block

Baseline 広く利用可能 *

この機能は広く実装されており、多くのバージョンの端末やブラウザーで動作します。2021年4月以降、すべてのブラウザーで利用可能です。

* この機能の一部は、対応レベルが異なる場合があります。

margin-blockCSS一括指定プロパティで、論理的なブロックの先頭と末尾のマージンを設定します。これは要素の書字方向やテキストの向きに応じて物理的なマージンに変換されます。

試してみましょう

margin-block: 10px 20px;
writing-mode: horizontal-tb;
margin-block: 20px 40px;
writing-mode: vertical-rl;
margin-block: 5% 20%;
writing-mode: horizontal-tb;
margin-block: 1rem auto;
writing-mode: vertical-lr;
<section id="default-example">
 <div id="container">
 <div class="row">One</div>
 <div class="row transition-all" id="example-element">Two</div>
 <div class="row">Three</div>
 </div>
</section>
#container {
 width: 300px;
 height: 200px;
 display: flex;
 align-content: flex-start;
 flex-direction: column;
 justify-content: flex-start;
}
.row {
 height: 33.33%;
 display: inline-block;
 border: solid #ce7777 10px;
 background-color: #2b3a55;
 color: white;
 flex-shrink: 0;
}
#example-element {
 border: solid 10px #ffbf00;
 background-color: #2b3a55;
}

構成要素のプロパティ

このプロパティは以下の CSS プロパティの一括指定です。

構文

css
/* <length> 値 */
margin-block: 10px 20px; /* 絶対的な長さ */
margin-block: 1em 2em; /* テキストの大きさに対する相対値 */
margin-block: 5% 2%; /* 直近のブロックコンテナーの大きさに対する相対値 */
margin-block: 10px; /* 先頭と末尾の両方を設定 */
margin-block: anchor-size(inline);
margin-block: calc(anchor-size(width) / 4) 1em;
/* キーワード値 */
margin-block: auto;
/* グローバル値 */
margin-block: inherit;
margin-block: initial;
margin-block: revert;
margin-block: revert-layer;
margin-block: unset;

このプロパティは、 margin-topmargin-bottom、または margin-rightmargin-left プロパティに、 writing-mode, direction, text-orientation で定義された値にしたがって対応します。

margin-block プロパティは、 1 つまたは 2 つの値を使用して指定します。

  • 1 つの値が指定された場合は、先頭と末尾の両方に同じマージンを適用します。
  • 2 つの値が指定された場合は、 1 つ目のマージンが先頭に、 2 つ目のマージンが末尾に指定されます。

margin-block プロパティは、 margin-top プロパティと同じ値を取ります。

公式定義

初期値 一括指定の次の各プロパティとして
適用対象margin と同じ
継承 なし
パーセント値レイアウトモデルに依存
計算値 一括指定の次の各プロパティとして
  • margin-block-start: 長さで指定されると相当する絶対的な長さ、パーセント値として指定されると指定値、それ以外では auto
  • margin-block-end: 長さで指定されると相当する絶対的な長さ、パーセント値として指定されると指定値、それ以外では auto
アニメーションの種類 length

形式文法

margin-block = 
<'margin-top'> {1,2}

<margin-top> =
<length-percentage> |
auto |
<anchor-size()>

<length-percentage> =
<length> |
<percentage>

<anchor-size()> =
anchor-size( [ <anchor-name> || <anchor-size> ] ? , <length-percentage>? )

<anchor-name> =
<dashed-ident>

<anchor-size> =
width |
height |
block |
inline |
self-block |
self-inline

ブロック方向の先頭と末尾のマージンを設定

CSS

css
div {
 background-color: yellow;
 width: 120px;
 height: auto;
 border: 1px solid green;
}
p {
 margin: 0;
 margin-block: 20px 40px;
 background-color: tan;
}
.verticalExample {
 writing-mode: vertical-rl;
}

HTML

html
<div>
 <p>テキストの例</p>
</div>
<div class="verticalExample">
 <p>テキストの例</p>
</div>

結果

仕様書

仕様書
CSS Logical Properties and Values Module Level 1
# propdef-margin-block

ブラウザーの互換性

関連情報

MDN の改良に協力

協力方法を知る

このページは MDN の貢献者によって に最終更新されました。

AltStyle によって変換されたページ (->オリジナル) /