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

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

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

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

CSS

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

Q&A

2回答

24152閲覧

<img>要素を親要素いっぱいに広げて表示するにはどうしたらよいでしょうか?

D.O

総合スコア55

HTML

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

CSS

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

0グッド

0クリップ

投稿2016/08/15 17:49

<img>要素を親要素いっぱいに広げて表示するにはどうしたらよいでしょうか?

イメージとして背景画像のbackground-size:contain;的な感じです。

親要素は正方形の領域で画面サイズに合わせて可変的にサイズが変わります。
画像は縦長もあれば横長もあります。
よろしくお願いします。

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

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

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

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

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

guest

回答2

0

HTML

1<div class="contain"><img src="https://placehold.jp/24/cc9999/993333/350x150.png" alt="横長"></div> 2<div class="contain"><img src="https://placehold.jp/24/99cc99/339933/150x350.png" alt="縦長"></div>

CSS

1.contain { 2 height: 300px; 3 margin: 30px; 4 overflow: hidden; 5 position: relative; 6 width: 300px; 7} 8.contain > img { 9 left: 50%; 10 min-height: 100%; 11 min-width: 100%; 12 position: absolute; 13 top: 50%; 14 transform: translate(-50%, -50%); 15} 16```**動くサンプル:**[https://jsfiddle.net/fufozz8x/1/](https://jsfiddle.net/fufozz8x/1/) 17 18 19--- 20 21**追記:** 22 23 24 25**動くサンプル:**[https://jsfiddle.net/fufozz8x/2/](https://jsfiddle.net/fufozz8x/2/)

投稿2016/08/15 18:12

編集2016/08/16 03:36
kei344

総合スコア69407

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

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

D.O

2016/08/16 03:24

解答ありがとうございます。 この方法はどちらかというと 背景でいうなら background-size:cover;的な感じかと思います。 「領域いっぱいに広がってくれる」という表現がよくなかったですね。紛らわしくてすみません。 画像がはみ出さないように親要素内に出来るだけ大きく表示するといういことです。 縦長の画像であればhightが100%,横長の画像であればwidthが100% しかも親要素は画面の横幅に合わせて伸縮する正方形の領域というイメージです。 分かりにくくてすみません。
kei344

2016/08/16 03:32

ああ、coverと勘違いしました。すいません。
guest

0

HTML

1<div class="contain img-h"><img src="01.jpg" alt="横長" width="277" height="156"></div> 2<div class="contain img-v"><img src="02.jpg" alt="縦長" width="156" height="277"></div>

CSS

1/*可変幅の親要素*/ 2.contain { 3 position: relative; 4 width: 30%; 5 margin: 20px; 6 border: 5px solid #ccc; 7} 8/*可変幅の親要素の領域を正方形に保つ*/ 9.contain:before { 10 content: ""; 11 display: block; 12 padding-top: 100%; 13} 14/*画像を親要素の中央に配置*/ 15.contain img { 16 position: absolute; 17 left: 50%; 18 top: 50%; 19 -webkit-transform: translate(-50%,-50%); 20 transform: translate(-50%,-50%); 21} 22/*横長画像の場合*/ 23.contain.img-h img { 24 width: 100%; 25 height: auto; 26} 27/*縦長画像の場合*/ 28.contain.img-v img { 29 width: auto; 30 height: 100%; 31}

静的に作るならこんな感じでしょうか。
親要素が可変幅で画像自身のサイズよりも大きくなった場合でも、
画像自身の比率を保ったまま親要素の中で拡大します。

中身の画像が縦長か横長かによってwidthとheightの値を変える必要があるので、
手動でclassを付けられない場合には画像の比率をJavaScriptで計算し、
動的にclassをつけてやる必要があります。

投稿2016/09/03 15:47

aKusano

総合スコア3763

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問