一枚だけ高さの違うimageを何とかしてslideshowのレイアウトが崩れないようにする
一枚だけ高さの違うimageを何とかしてslideshowのレイアウトが崩れないようにする Slideshow Gallery 1 / 6 2 / 6 3 / 6 4 / 6 5 / 6 6 / 6 ❮ ❯ 上のslide show 3/6 花 が1,024px × 640px 他は1,024px × 576px 一枚だけheight が高い。 style="width: 100%" を解除し、object-fit: cover; を指定すると縮小表示され枠内に収まる。しかし、拡大時やスマホ表示で大きさそのままとなってしまうから戻す。 aspect ratio を常に16:9 に保つには、まずwidthを指定 30vw とする。これにheight はcalc()を使う。16:9 なら height: calc(30vw * 0.5625), 4:3なら height: calc(30vw * 0.75) 検索してたくさん出てきた <div> に入れて padding-top: 56.25% とするやり方では正しく要素を配置しないとレイアウトが崩れてしまったため、要素・Elementを追加せずに、CSSで指定する方法にたどり着いた。 slideshow に使っているjavaScript の img tag から 文字を取得する。</div> background-image:url(); では、img tag ではないから attribute alt="花" を取得できずに caption が undefined になってしまう。 slid