いわゆるレスポンシブデザインとは、異なる画面解像度、異なるピクセル密度比、異なる幅を持つ端末デバイスで Web ページのレイアウトを適応的に調整できることを意味します。レスポンシブ デザインの本来の目的は、元の PC ウェブサイトをモバイル端末と互換性のあるものにすることです。ほとんどのレスポンシブ Web ページは、メディア クエリとさまざまなスタイルの CSS ファイルの読み込みを通じて実装されます。このような柔軟なレイアウトにより、さまざまなデバイス端末上で Web サイトのレイアウトがより合理的になります。この記事では主にHTML5のpicture要素のレスポンシブ画像処理の詳細な解説を紹介していますが、編集者が非常に優れていると思ったので、参考として共有させていただきます。編集者をフォローして見てみましょう。皆さんのお役に立てれば幸いです。
レスポンシブデザインには多くの利点がありますが、多くの欠点もあります。 PCとモバイル端末は同じWebサイトにアクセスするため、PCではトラフィック制限を気にする必要はありませんが、モバイル端末ではトラフィック制限を無視できません。
さまざまな端末モデルの画面幅とピクセル密度に適応させるために、通常、次の方法を使用して画像の CSS スタイルを設定します:
<style>
img{
max-width:100%;
height:auto;
}
</style>
画像の最大幅を 100% に設定して、画像が親要素の幅を超えないようにします。親要素の幅が変更されると、画像の幅も変更されます。画像は、独自の幅と高さの比率に従って拡大縮小されます。
このように、モバイル デバイスでレスポンシブ Web ページの画像にアクセスすると、画像の解像度のみが拡大され、大きな画像が PC にダウンロードされます。これにより、トラフィックが無駄になるだけでなく、帯域幅も無駄になります。 Web ページを開く速度が遅くなり、ユーザー エクスペリエンスに重大な影響を与えます。
新しいソリューション:
は HTML5 の新しい要素です
が現在の 要素と連携する場合コラボレーションにより、レスポンシブな画像処理のプロセスが強化され、その中に複数の タグを設定して、さまざまな条件に応じてロードする異なる画像ファイル名を指定できます。さまざまな条件 条件に応じてさまざまな画像を読み込みます。これらの条件には、ウィンドウの現在の高さ (ビューポート)、幅 (width)、向き (orientation)、ピクセル密度 (dpr) などが含まれます。いくつかの栗
次の栗は、画面幅が異なると異なる画像を読み込みます。ページ幅が 320px から 640px までの場合は、middle.png が読み込まれます。次の栗、画面の向きが条件として追加されます; 画面の向きが横の場合は、_landscape.png で終わる画像を読み込みます。 画面の向きが縦の場合は、_portrait.png で終わる画像を読み込みます。 3. 画面のピクセル密度は次の栗の条件として追加されます。ピクセル密度が 2x の場合は、画像 _retina.png 2x をロードします。ピクセル密度が 1x の場合は、retina サフィックスなしで画像をロードします。 . 次のクリに画像ファイル形式を追加し、webp 形式の画像がサポートされている場合は webp を読み込みます。
<picture>
<source media="(min-width: 320px) and (max-width: 640px)" srcset="img/minpic.png">
<source media="(min-width: 640px)" srcset="img/middle.png">
<img src="img/picture.png" alt="this is a picture">
</picture>
5. ページの幅の説明を追加します。
<picture>
<source media="(min-width: 320px) and (max-width: 640px) and (orientation: landscape)" srcset="img/minpic_landscape.png">
<source media="(min-width: 320px) and (max-width: 640px) and (orientation: portrait)" srcset="img/minpic_portrait.png">
<source media="(min-width: 640px) and (orientation: landscape)" srcset="img/middlepic_landscape.png">
<source media="(min-width: 640px) and (orientation: portrait)" srcset="img/middlepic_portrait.png">
<img src="img/picture.png" alt="this is a picture">
</picture>
6. ウィンドウの幅が 800px 以上の場合は、現在の幅を超えない最大の画像をロードすることを選択します。画像の
<picture>
<source media="(min-width: 320px) and (max-width: 640px)" srcset="img/minpic.png,img/minpic_retina.png 2x">
<source media="(min-width: 640px)" srcset="img/middle.png,img/middle_retina.png 2x">
<img src="img/picture.png,img/picture_retina.png 2x" alt="this is a picture">
</picture>
互換性:
現在、Chrome、Firefox、Opera のみと互換性があります:
利点:
適切なサイズの画像ファイルをロードします。利用可能な帯域幅が最大限に活用されるようにします。
異なる幅でのレイアウト変更に対応するために、異なる方法でトリミングされ、異なるアスペクト比を持つ画像をロードします。
手順:
機能の タグを作成します。
幅 (max-width、min-width) などのメディア属性を追加します。方向 (向き) など;
srcset 属性を追加し、属性値は対応する画像ファイル名をロードします。 Retina ディスプレイなど、異なるピクセル密度を提供したい場合は、追加のファイル名を srcset 属性に追加できます
構文
上記のコード例からわかるように、js やサードパーティのライブラリを導入せず、CSS に含まれるメディア クエリを使用せずに、HTML のみを使用して
要素をレスポンシブに宣言できます。
<ソース>要素
タグ自体には属性がありません。魔法の部分は、 が のコンテナとして使用されることです。ビデオやオーディオなどのマルチメディアをロードするために使用される 要素が画像のロードを処理するように更新され、いくつかの新しい属性が追加されました:
srcset (必須)
単一の画像ファイル パスを受け入れます(例: srcset="img/minpic.png")
またはピクセル密度を説明するカンマ区切りの画像パス (例: srcset="img/minpic.png,img/minpic_retina.png 2x")、1xデフォルトでは使用されません。
media (オプション)
CSS @media セレクターでわかるように、検証されたメディア クエリを受け入れます (例: media="(min-width: 320px)")。
サイズ (オプション)
単一の幅の説明 (sizes="100vw" など) または単一のメディア クエリの幅の説明 (sizes="(min-width: 320px) 100vw" など) を受け取ります。または、カンマ区切りのメディア クエリ幅の説明 (例:sizes="(min-width: 320px) 100vw, (min-width: 640px) 50vw, calc(33vw - 100px)") 最後のものがデフォルトとして使用されます。
type(オプション)
サポートされている MIME タイプ (type="image/webp" または type="image/vnd.ms-photo" など) を受け入れます
ブラウザは、これらのヒントと属性に基づいて正確なものを読み込みます画像リソース。タグのリスト順に従います。ブラウザは最初の適切な 要素を使用し、後続の タグを無視します。
最後の 要素を追加します
要素は、ブラウザがサポートしていない場合、または一致するソース タグがない場合に表示されるように使用されます。 内で タグを使用することは必須です。忘れると画像は表示されません。
を使用してデフォルトの画像表示を宣言します。 タグを の最後に配置すると、ブラウザは タグを見つける前に タグを無視します。このイメージ タグには、alt 属性を記述する必要もあります。
この記事は他の多くの記事を参考にしています。画像の紹介はすべてここにありますので、今すぐ試してみましょう~
関連する推奨事項;
レスポンシブフレームワークブートストラップグリッドシステムを例で説明します
いくつかのレスポンシブフレームワークが適していますWeb プログラマー向け
HTML5 レスポンシブ バナー制作チュートリアル
以上がHTML5 の Picture 要素を使用して画像をレスポンシブに処理する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。