B.picture要素、source要素、media属性

Webデザイン

カテゴリー: レスポンシブ画像  閲覧数:734 配信日:2015-08-17 19:47





B方式.pictureタグ + sourceタグ(media属性 srcset属性) + imgタグ(srcset属性)


画像のアートディレクション
アートディレクションによる選択
→ 表示される画面に応じて画像を出し分け
→ ウィンドウサイズに合わせて画像を切り替え
・pictureタグ
・sourceタグmedia属性、sourceタグsrcset属性
・imgタグsrcset属性、もしくは、imgタグsrc属性


具体例1
・ウィンドウサイズが 1200px 以上なら 1200w.png 読込
・ウィンドウサイズが 1000px 以上なら 1000w.png 読込
・ウィンドウサイズが 800px 以上なら 800w.png 読込
・ウィンドウサイズが 600px 以上なら 600w.png 読込
・ウィンドウサイズが 400px 以上なら 400w.png 読込
・ウィンドウサイズが 200px 以上なら 200w.png 読込
・上記以外(ウィンドウサイズが 200px 未満)なら img srcset で指定した内容(800w.png) 読込
<picture>
 <!--[if IE 9]><video style="display: none;"><![endif]-->
 <source srcset="./img/1200w.png" media="(min-width: 1200px)">
 <source srcset="./img/1000w.png" media="(min-width: 1000px)">
 <source srcset="./img/800w.png" media="(min-width: 800px)">
 <source srcset="./img/600w.png" media="(min-width: 600px)">
 <source srcset="./img/400w.png" media="(min-width: 400px)">
 <source srcset="./img/200w.png" media="(min-width: 200px)">
 <!--[if IE 9]></video><![endif]-->
 <img srcset="./img/800w.png" alt="CSSデモ">
</picture>


動作確認
・成功


C方式.srcset属性 x記述子


ピクセル密度デスクリプタ(1x、1.5x、2x、3x など)を使用
Retina対応
→ 高解像度のディスプレイをサポート
→ Retinaディスプレイ用に画像を切り替え
・「imgタグsrcset属性 x記述子」 もしくは 「sourceタグsrcset属性 x記述子」

上記に「pictureタグ × sourceタグ」が加わる場合もあり
・つまり「srcset属性 x記述子」がある場合は、常にC方式
※「B方式」でかつ「C方式」なケースもあり得ると言うこと!

動作確認
・Retinaディスプレイを保持していないため未検証

週間人気ページランキング / 6-13 → 6-19
順位 ページタイトル抜粋 アクセス数
1 「東京都」のカラーコード取得は難しい | カラーコード(色) 10
2 鉄道会社毎のカラーコード | カラーコード(色) 7
2 「パッケージ化されてない拡張機能を読み込む」でインストールした拡張は、chromeを「更新」すると正常動作しなくなることがあります。 | Chrome 拡張機能 7
3 「Chrome拡張機能」開発中に遭遇したエラー | Chrome 拡張機能 6
3 RGBの種類 / ビットカラー | RGB(色) 6
3 Design 0 6
4 金融機関ブランドカラー / コーポレートカラー | カラーコード(色) 4
4 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない | モバイルデザイン(デザイン) 4
5 HSV / HSB 3
5 RGB ⇔ Lab | 色変換(色) 3
5 「マウスオーバー」「ロールオーバー」「ホバー」の違い | CSS 3
5 カラーコード / 色コード | カラーコード(色) 3
5 効果を打ち消すスタイルシート | CSS 3
5 「overflow」効果を打ち消すスタイルシートは、「overflow: auto;」 3
5 「:hover」「z-index」を組み合わせて使用すると、正常動作しないことがある | z-index(CSS) 3
5 utf-8ではなく、UTF-8 | HTML 3
6 似顔絵ジェネレーター : 似顔絵メーカー / NIGAOE MAKER 2
6 16進数カラーコード / 2進数 2
6 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 2
6 max-width: 100%の効果を打ち消すには、max-width: none; | CSS 2
2025/6/20 1:01 更新
指定期間人気ページランキング / 2020-5-30 → 2025-6-19
順位 ページタイトル抜粋 アクセス数
1 RGB ⇔ Lab | 色変換(色) 8608
2 「マウスオーバー」「ロールオーバー」「ホバー」の違い | CSS 4552
3 血の色 / #b30000 / #360800 / #ff0000 | 色 3724
4 Design 0 3692
5 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 2691
6 RGBの種類 / ビットカラー | RGB(色) 2633
7 「bgcolor」「background-color」「background」の違い | CSS 1969
8 金融機関ブランドカラー / コーポレートカラー | カラーコード(色) 1867
9 16進数カラーコード / 2進数 1823
10 コズミックブルーが何色か分からない | 色 1801
11 「:hover」「z-index」を組み合わせて使用すると、正常動作しないことがある | z-index(CSS) 1659
12 「Font Awesome 4」と「Font Awesome 5」の違い(Font Awesome バージョン4からのアップグレード) | Font Awesome(フォント) 1644
13 「属性」「プロパティ」「アトリビュート」の違い | CSS 1590
14 「Bootstrapデザイン」✕「グラフ」 | 2系(Bootstrap) 1506
15 「パッケージ化されてない拡張機能を読み込む」でインストールした拡張は、chromeを「更新」すると正常動作しなくなることがあります。 | Google Chrome(ブラウザ) 1404
16 Chrome でキャッシュを効かさない | Google Chrome(ブラウザ) 1355
17 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない | モバイルデザイン(デザイン) 1284
18 HSLとHSVの違い | 色変換(色) 1148
19 「東京都」のカラーコード取得は難しい | 色 1147
20 「Chrome拡張機能」開発中に遭遇したエラー | Chrome 拡張機能 1095
2025/6/20 1:01 更新