質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

3908閲覧

margin-rightが効かないのを解決したい

退会済みユーザー

退会済みユーザー

総合スコア0

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2020/01/29 07:28

html

1 2 <div class="box"> 3 <div class="a"> 4 a 5 </div> 6 <div class="b">b</div> 7 </div> 8 9 10``` 11```css 12.box { 13 background: red; 14 width:100%; 15 height: 200px; 16 position: absolute; 17 color: #fff 18 19} 20 21.a { 22 background: #333; 23width: 100%; 24 margin-left: -100px 25 26} 27 28.b { 29 background: #999; 30width: 100%; 31 margin-left: 100px 32} 33``` 34 35margin-keftは効くのでこの違いはなぜなのか知りたいです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

'margin-left' + 'border-left-width' + 'padding-left' + 'width' + 'padding-right' + 'border-right-width' + 'margin-right' = width of containing block
(略)
If all of the above have a computed value other than 'auto', the values are said to be "over-constrained" and one of the used values will have to be different from its computed value. If the 'direction' property of the containing block has the value 'ltr', the specified value of 'margin-right' is ignored and the value is calculated so as to make the equality true.

10.3.3 Block-level, non-replaced elements in normal flow | Visual formatting model details

勝手訳:
'margin-left' + 'border-left-width' + 'padding-left' + 'width' + 'padding-right' + 'border-right-width' + 'margin-right' = 包含ブロックの幅
(略)
上記すべてが'auto'以外である場合, それらの値は「制限しすぎ("over-constrained")」と呼ばれ、そのうち一つは設定された値と違う値が取られます。もし'direction'プロパティが'ltr'であるなら、'margin-right'の設定値は無視され、上記等式が成り立つように計算されます。


ということなので、ご提示のコードについてwidth: 100%;width: auto;などとすれば、お望みの結果になるのではないかと思います。

投稿2020/01/29 08:14

編集2020/01/29 08:17
Lhankor_Mhy

総合スコア36134

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/01/29 09:35

上記すべてが'auto'以外と言いますが、'border-left-width' + 'padding-leftは設定していないのですが。widthをautoにしなければならないのでしょうか。
Lhankor_Mhy

2020/01/29 12:03

「ご提示のコードについてwidth: 100%;をwidth: auto;**など**とすれば」と書きました。 なので、「widthをautoにしなければならない」という意図の回答ではありません。
退会済みユーザー

退会済みユーザー

2020/01/30 00:08

padding-leftを試しにautoにしましたが、margin-rightは効かなかったのですが。widthをauto以外での解決策はありますか。あるのであれば教えてください。
Lhankor_Mhy

2020/01/30 00:34 編集

margin-left: auto; または direction: rtl; です。 margin-left: auto; が効くのは、マイナスマージンだけです。 direction: rtl; は包含ボックスに当ててください。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問