<img>要素を親要素いっぱいに広げて表示するにはどうしたらよいでしょうか?
イメージとして背景画像のbackground-size:contain;的な感じです。
親要素は正方形の領域で画面サイズに合わせて可変的にサイズが変わります。
画像は縦長もあれば横長もあります。
よろしくお願いします。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答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総合スコア69407
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
総合スコア3763
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/08/16 03:24
2016/08/16 03:32