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

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

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

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

CSS

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

Q&A

1回答

918閲覧

img画像の横幅について

masaya9460

総合スコア6

HTML

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

CSS

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

0グッド

0クリップ

投稿2020/06/20 21:24

編集2020/06/20 21:37

imgの横幅についてお聞きしたいです。
imgタグを一枚だけ設定すると、slider__container__slidersに合わせて、width1000px、height500pxになります。
これは理解できるのですが、imgタグを二枚設定すると、画像一枚ごとのサイズがwidth640、height500pxになります。
なぜ、widthの値が640pxという中途半端な値が出てくるのでしょうか。

また、複数枚設定したときにどのようにしたら、子要素のimgが親要素に合わした値になるのでしょうか。
どなたかにご教授頂けたら幸いです。よろしくお願いいたします。

html

1 <div class="slider__container"> 2 <div class="slider__container__sliders"> 3 <img src="images/cat_1.jpg" alt=""> 4 <img src="images/cat_2.jpg" alt=""> 5 </div> 6 </div>

css

1*{ 2 box-sizing: border-box; 3} 4img { 5 width: 100%; 6 height: auto; 7} 8 .slider__container { 9 max-width: 1000px; 10 width: 60%; 11 margin: auto; 12 overflow-x: hidden; 13 } 14 .slider__container__sliders { 15 background: pink; 16 display: flex; 17 width: 100%; 18 height: 500px; 19 } 20

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

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

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

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

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

kei344

2020/06/21 01:30

画像の縦横ピクセルも提示してください。
Lhankor_Mhy

2020/06/22 01:44

こんにちは。 >imgタグを一枚だけ設定すると、slidercontainerslidersに合わせて、width1000px、height500pxになります。 >これは理解できるですが、 とのことですが、当方で、ご提示のコードのimgを一つにして試してみましたが、1000pxになりませんでした。 https://jsfiddle.net/Lhankor_Mhy/3ayct8kn/ おそらく、ご提示いただいていない部分のコードの影響だと思いますので、問題が再現するコードをご提示ください。
guest

回答1

0

以下の前提で回答します。

css

1 .slider__container { 2 max-width: 1000px; 3 width: 100%; /* 60% は間違い */ 4 margin: auto; 5 overflow-x: hidden; 6 }

まず、初期値として以下のCSSが効いています。

css

1img { 2 flex: 0 1 auto; 3} 4 5.slider__container__sliders { 6 align-items: stretch; 7}

さて、imgのサイズについて、

  • widthについて、ベースサイズは100%つまり1000pxですが、flex: 0 1 autoなので、最小コンテンツ幅まで縮小をするため、確定しません。
  • heightは、autoなので拘束がなく、align-items: stretchが効いているので、フレックスコンテナの高さいっぱいに広がります。つまり、500pxです。
  • 高さが定まり、幅が不定のままなので、内在アスペクト比に従って最小コンテンツ幅が決まります。以下のような計算によります。

たとえば、画像のサイズが1280*1000だとすると、内在アスペクト比は 1280 : 1000。これに従うので、imgの幅をwとすると、1280 : 1000 = w : 500 です。これを解くと640です。

  • 最小幅が決まったため、imgの幅が決まります。以下のような計算になります。
  1. フレックスアイテム(=img)が2つでベースサイズが1000なので、1000*2 で合計で2000。
  2. フレックスコンテナの幅が1000、2000-1000で、足りない幅は1000。
  3. フレックスアイテムが2つなので、アイテム当たりの縮小幅は 1000/2 で500。
  4. 縮小後のフレックスアイテムの幅は 1000-500で、500。
  5. これは最小幅よりも小さいため、フレックスアイテム(=img)の幅は640。

以上、私も理解が浅い部分があるので、間違っていそうな箇所がありましたらご指摘ください。

投稿2020/06/22 08:32

編集2020/06/22 08:39
Lhankor_Mhy

総合スコア36960

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問