margin-left
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.
margin-left は CSS のプロパティで、要素の左側のマージン領域を設定します。正の数を指定すると、隣との間が遠くなるように配置され、負の数を指定すると、近くなるように配置します。
試してみましょう
margin-left: 1em;
margin-left: 10%;
margin-left: 10px;
margin-left: 0;
<section id="default-example">
<div id="container">
<div class="col"></div>
<div class="col transition-all" id="example-element"></div>
<div class="col"></div>
</div>
</section>
#container {
width: 300px;
height: 200px;
display: flex;
align-content: flex-start;
justify-content: flex-start;
}
.col {
width: 33.33%;
border: solid #5b6dcd 10px;
background-color: rgba(229, 232, 252, 0.6);
flex-shrink: 0;
}
#example-element {
border: solid 10px #ffc129;
background-color: rgba(255, 244, 219, 0.6);
}
2 つの隣り合うボックスの垂直マージンは融合することがあります。これはマージンの相殺と呼ばれています。
まれに幅の制約がきつすぎると (つまり、 width, margin-left, border, padding, コンテンツ領域, margin-right がすべて定義されていた場合)、 margin-left は無視され、 auto が設定されていたときと同じ計算値になります。
構文
/* <length> 値 */
margin-left: 10px; /* 絶対的な寸法 */
margin-left: 1em; /* 文字の寸法からの相対 */
margin-left: 5%; /* 直近のブロックコンテナーの幅からの相対 */
/* キーワード値 */
margin-left: auto;
/* グローバル値 */
margin-left: inherit;
margin-left: initial;
margin-left: revert;
margin-left: revert-layer;
margin-left: unset;
margin-left プロパティは auto キーワード、または <length> や <percentage> で指定されます。正の数、ゼロ、負の数が指定できます。
値
<length>-
マージンの寸法を固定値で表したものです。
<percentage>-
マージンの寸法を包含ブロックのインラインサイズ(
writing-modeで横書き言語と定義されている場合は width)に対するパーセント値で示したものです。 auto-
左マージンは未使用の水平方向の余白を共有します。これは主に使用されているレイアウトモードによって決定されます。
margin-leftとmargin-rightの両方がautoの場合は、両方に均等に割り当てられます。それ以外の場合は以下の表のとおりです。displayの値floatの値positionの値autoの計算値コメント inline,inline-block,inline-table任意 staticまたはrelative0インラインレイアウトモード block,inline,inline-block,block,table,inline-table,list-item,table-caption任意 staticまたはrelative0。ただしmargin-leftとmargin-rightが共にautoであった場合を除く。この場合、その要素が親の中で中央揃えされる値が設定される。ブロックレイアウトモード block,inline,inline-block,block,table,inline-table,list-item,table-captionleftまたはrightstaticまたはrelative0ブロックレイアウトモード (浮動要素) すべての table-*、ただしtable-captionを除く任意 任意 0内部の table-*要素にはマージンがない。代わりにborder-spacingを使用のこと任意、ただし flex,inline-flex,table-*を除く任意 fixedまたはabsolute0。ただしmargin-leftとmargin-rightが共にauto出逢った場合を除く。この場合、利用可能なwidthの中で境界領域が中央揃えされる値が設定される (fixed の場合)。絶対位置指定レイアウトモード flex,inline-flex任意 任意 0。ただし、水平方向に正の余白がある場合を除く。この場合、autoを指定したすべてのマージンに均等に分配される。フレックスボックスレイアウトモード
公式定義
| 初期値 | 0 |
|---|---|
| 適用対象 | table-caption, table, inline-table 以外の表の display 種別を除くすべての要素。 ::first-letter にも適用されます。 |
| 継承 | なし |
| パーセント値 | 包含ブロックの幅に対する相対値 |
| 計算値 | 指定されたパーセント値または絶対的な長さ |
| アニメーションの種類 | length |
形式文法
margin-left =
<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
例
>margin-left をパーセント値で指定
margin-left をパーセント値で指定すると、コンテナーのインラインサイズに対する相対サイズになります。
HTML
<p>
A large rose-tree stood near the entrance of the garden: the roses growing on
it were white, but there were three gardeners at it, busily painting them red.
</p>
<p class="example">
Alice thought this a very curious thing, and she went nearer to watch them,
and just as she came up to them she heard one of them say, "Look out now,
Five! Don't go splashing paint over me like that!"
</p>
<p>
"I couldn't help it," said Five, in a sulky tone; "Seven jogged my elbow."
</p>
CSS
.example {
margin-left: 50%;
}
結果
仕様書
| Specification |
|---|
| CSS Box Model Module Level 3> # margin-physical> |
ブラウザーの互換性
Loading…