あまりないかもしれませんが、サイズ指定されたエリアの中に、様々なサイズの画像を縦横中央+長い方で縮小して設置する方法です。
background-image
を使用すれば簡単ですが、ここではimgタグのまま行う方法を紹介します。
下記のjQueryプラグインを使用すると簡単ですが、imgタグをbackground-imageに変換することで可能にしています。
https://github.com/karacas/imgLiquid
僕は、以前はこちらをよく使用していましたが、flexboxが使用できるようになった今ではCSSのみで対応できます。
対応方法
下記のような200×200のエリアを例に説明したいと思います。
data:image/s3,"s3://crabby-images/fc399/fc399a9d5e5ff55a42ca610e4d661b0300b35913" alt="スクリーンショット 2018-01-21 22.22.28.png"
<div class="imageBox"></div>
.imageBox {
$areaSize: 200px;
width: $areaSize;
height: $areaSize;
border: solid 1px #ccc;
background: #eee;
}
対応方法
HTMLを以下のようにして、画像を設置します。
<div class="imageBox">
<img arc="" alt="" />
</div>
CSSは下記のように修正します。
.imageBox {
$areaSize: 200px;
width: $areaSize;
height: $areaSize;
border: solid 1px #ccc;
background: #eee;
display: flex;
align-items: center;
justify-content: center;
> img {
max-width: $areaSize;
max-height: $areaSize;
width: auto;
height: auto;
}
}
まず、.imageBox
(画像を入れる要素)に、display: flex;
, align-items: center;
, justify-content: center;
を指定します。
これによって、子要素のimgタグを縦横中央に設置します。
さらに、子要素のimgタグに縦横サイズの指定を追記ます。
縦横の最大を、親要素のサイズになるように、max-width: $areaSize;
, max-height: $areaSize;
を指定します。
これによって、縦横のより長い方が縮小され、もう片方(縦/横)も同じ比率で縮小されます。
明示的にwidth: auto;
, height: auto;
を指定していますが、なくても問題ないです。
また、サイズは変数化しておいた方が、修正漏れなども置きなくなるので、変数化をおすすめします。
縦がエリア以上の場合
data:image/s3,"s3://crabby-images/bd47b/bd47b626326eed3b7778b01ff3de59c8fc411246" alt="スクリーンショット 2018-01-21 22.40.17.png"
横がエリア以上の場合
data:image/s3,"s3://crabby-images/8c375/8c37576cf626304e2b9a9f74e49d319b4abe47e8" alt="スクリーンショット 2018-01-21 22.41.30.png"
縦横がエリア以下の場合
data:image/s3,"s3://crabby-images/d1150/d1150e4143dcb30554e3dad97ece0a0e4f55116b" alt="スクリーンショット 2018-01-21 22.42.41.png"
縦横がエリア以上の場合
data:image/s3,"s3://crabby-images/e5fa1/e5fa1796000318896239b6740b3fa7b3d137f073" alt="スクリーンショット 2018-01-21 22.43.34.png"
この場合、横の方がよりエリアより大きかったので、横ベースで縮小されています。
まとめ
以上が、固定エリアの中に可変画像を中央寄せかつ、長い方で縮小して設置する方法でした。