「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > CSS グリッドとフレックスボックスを使用したレスポンシブ Web デザイン

CSS グリッドとフレックスボックスを使用したレスポンシブ Web デザイン

2024 年 8 月 7 日に公開
ブラウズ:240

Responsive Web Design with CSS Grid and Flexbox

CSS グリッドとフレックスボックスを使用したレスポンシブ Web デザイン

レスポンシブ Web デザインは、さまざまな種類のデバイスや画面サイズで適切に動作するように Web サイトを開発する方法です。レスポンシブ デザインでは、デバイスごとにサイトの複数のバージョンを作成する必要がなく、柔軟なグリッドとレイアウト、メディア クエリ、流動的な画像を使用して、すべてのプラットフォームでユーザー エクスペリエンスを向上させます。

レスポンシブ Web デザインが重要な理由

世界中で携帯電話やタブレットを使用してインターネットを閲覧する人が増えているため、応答性の高い Web サイトを持つことはもはや選択肢ではなく、必須となっています。レスポンシブデザインにより、消費者は使用しているデバイスに関係なくコンテンツにシームレスにアクセスできるため、使いやすさが向上します。また、コンテンツが視覚的に一貫性があり、デバイス間で簡単に読み取れるようにすることで、ユーザー エクスペリエンスも向上します。これにより、フラストレーションが軽減され、インタラクションが促進されます。さらに、レスポンシブ デザインは Web サイトを将来にわたって使用できるため、大規模な再設計を行うことなく新しいデバイスに適応させることができます。

今日は、レスポンシブ Web デザインの基本を見て、特に 2 つの強力な CSS テクニック、Flexbox と CSS Grid に焦点を当てます。カラフルなボックスと数字を備えたシンプルな Web サイトを使用して、これらのレイアウトがさまざまな画面サイズにどのように適応するかを示します。

レスポンシブ Web デザインの簡単な歴史

レスポンシブ Web デザインは、インターネットの初期の頃から大きく変化しました。メディア クエリ。画面サイズ、解像度、方向などのデバイスの特性に基づいてスタイルを適用します。は 2000 年代初頭に導入され、Flexbox は 2012 年に発売され、CSS グリッドは 2017 年に採用されました。これらの革新により、デザイナーはさまざまなデバイス上で適応可能なレイアウトを作成できるようになり、ユーザーにより良いエクスペリエンスを提供できるようになりました。

CSS グリッドとフレックスボックスを使用したレスポンシブ レイアウトの作成

それでは、Flexbox と CSS グリッドがどのように機能するかを示す実際の例をいくつか見てみましょう。

レスポンシブグリッドレイアウト: カラーグリッド

CSSグリッドを使用して簡単なレイアウトを作成します。

グリッド レイアウトの HTML:



    Color Grid
1
2
3
4
5
6

HTML:

  • HTML マークアップは、異なる番号と背景色を持つレスポンシブ コンテナ (グリッド コンテナ) とカラフルなボックス (グリッド アイテム) を作成します。ビューポート メタ タグを使用すると、さまざまなデバイス上でレイアウトを拡大縮小できます。

グリッド レイアウトの CSS:

/* styles.css */
body {
    margin: 0;
    font-family: Arial, sans-serif;
    background: #f0f0f0;
}

.grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap: 10px;
    padding: 20px;
}

.grid-item {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100px;
    color: #fff;
    font-size: 2em;
    border-radius: 8px;
}

CSS:

  • グリッド レイアウトの CSS は、応答性を高めるためにさまざまなグリッド プロパティを使用します。表示: グリッド。宣言では、grid-container クラスの要素をグリッド コンテナとして設定するため、グリッドが提供するすべての機能を利用できるようになります。グリッド テンプレート列:repeat(auto-fit, minmax(100px, 1fr));プロパティは、グリッド内の列の構造を定義します。このプロパティは、利用可能なスペースに基づいて列の数を自動的に調整します。各列の最小幅は 100 ピクセル、最大は利用可能なスペースの 1 部分 (1fr) です。この設計により、グリッドをさまざまな画面サイズに適応させることができるため、グリッド項目が溢れたり、見苦しい隙間が生じたりすることがなくなります。ギャップ: 10px;プロパティは、グリッド項目に一貫した間隔を適用します。最後に、display: flex; を使用して Grid-Item 要素をスタックします。そして、justify-content: center; を使用してコンテンツを中央に配置します。そして、align-item: center。このように、各項目がバランスよく整理されています。

レスポンシブ Web デザインの例: グリッド レイアウト

このグリッド レイアウトは次のものを使用します:

  1. 動的列数: グリッドはビューポートの幅に合わせて列数を自動的に調整します。項目の最小サイズは 100 ピクセルです。
  2. 柔軟なサイズ設定: 自動調整により、必要に応じてボックスが再配置され、すべてがより整理された外観になります。
  3. メディア クエリ: ここには実際には書かれていませんが、さまざまな画面サイズでグリッド要素がどのように動作するかは、レスポンシブ グリッド プロパティを使用したメディア クエリの概念を示しています。

レスポンシブ フレックスボックス レイアウト: カラー行

次に、Flexbox を使用して、色付きのボックスの単純な行を作成しましょう。

フレックスボックス レイアウトの HTML:



    Color Row
1
2
3
4

HTML:

  • グリッドの例と同様に、ここの HTML では、色付きの数字を表示するフレックス項目ボックスを備えたフレックス コンテナが作成されます。

フレックスボックス レイアウトの CSS:

/* styles.css */
body {
    margin: 0;
    font-family: Arial, sans-serif;
    background: #f5f5f5;
}

.flex-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding: 20px;
    gap: 10px;
}

.flex-item {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100px;
    width: 100px;
    color: #fff;
    font-size: 2em;
    border-radius: 8px;
}

CSS:
ここの CSS は、Flexbox プロパティを使用して、さまざまな画面サイズに適応する応答性の高いレイアウトを作成します。ディスプレイ: フレックス; .flex-container 内の は、その子要素、または (フレックス項目)、Flexbox 機能を提供します。フレックスラップ: ラップ;プロパティを使用すると、コンテナの幅を超えた場合にアイテムを複数行にフローできます。 justify-content: center;プロパティはフレックス項目を主軸に沿って中央に配置するため、項目の数に関係なくバランスの取れたレイアウトになります。ギャップ: 10px;このプロパティにより、項目間に均一な間隔が導入され、全体的な構成が改善されます。各 .flex-item は、display: flex; を使用するフレックス コンテナでもあります。 justify-content: center; を使用して、内部コンテンツをさらに配置できるようにし、垂直方向と水平方向の両方で中央揃えにします。および align-item: center;。高さの固定寸法: 100px;幅: 100px;均一性を提供し、これらのプロパティの組み合わせにより、レイアウトに快適な外観を与えながら、さまざまなデバイスのニーズに適応します。

レスポンシブ Web デザインの例: フレックスボックス レイアウト

このフレックスボックス レイアウトは、いくつかのレスポンシブ デザイン特性を示しています。

  1. フレックス ラップ: フレックス ラップ: ラップ;
  2. プロパティは、ボックスが行に収まらない場合に次の行に移動し、さまざまなビューポート幅に適応します。
  3. アイテムを中央揃え: 画面サイズに関係なくアイテムは中央に配置され、全体的なプレゼンテーションが向上します。
  4. 固定サイズ: ボックスには特定のサイズがありますが、使用可能なスペースに基づいてラップおよび再調整され、レスポンシブなレイアウトが可能になります。

CSS グリッドとフレックスボックスの比較

CSS でのレイアウト設計に関しては、グリッドとフレックスボックスはどちらも優れた選択肢ですが、目的は異なります。 CSS グリッドは、行と列を含む複雑なグリッド構造を作成できる 2 次元レイアウト システムであり、Web アプリケーションやダッシュボードなど、両方の次元を正確に制御する必要があるレイアウトに最適です。一方、Flexbox は 1 次元のレイアウト モデルであり、単一の軸 (水平方向または垂直方向) に沿ってスペースを分散するのに最適であり、より単純なレイアウトや、ボタンやナビゲーション メニューなどの小さなコンポーネントに最適です。要素が両方の軸にわたって整列する必要がある包括的で構造化されたレイアウトにはグリッドを選択するかもしれませんが、コンテンツ サイズに対応する必要がある適応性のある流動的なレイアウトには Flexbox が最適です。最終的には、プロジェクトの具体的なニーズに応じて選択する必要があります。多くの場合、両方を組み合わせて補完的に使用すると、最良の結果が得られます。

結論

CSS グリッドとフレックスボックスを使用すると、どのデバイスでも見栄えの良い、適応性のあるレイアウトを作成できます。これらの例は、動的デザインを実装することがいかに簡単であるかを示しています。

今ではあなたの番です!これらのテクニックを試し、色やレイアウト設定を変更し、楽しくて反応の良いデザインをいかに簡単に作成できるかを確認してください。

ソース:
https://www.w3schools.com/css/css3_flexbox.asp
https://www.w3schools.com/css/css_grid.asp
https://developer.mozilla.org/en-US/docs/Learn/CSS/CSS_layout
https://kinsta.com/blog/sensitive-web-design/#4-flexbox-layout
https://css-tricks.com/snippets/css/a-guide-to-flexbox/
https://css-tricks.com/snippets/css/complete-guide-grid/
https://blog.logrocket.com/css-flexbox-vs-css-grid/#:~:text=行を操作するときに役立つ主要なレイアウト スタイル。

リリースステートメント この記事は次の場所に転載されています: https://dev.to/wendyver/sensitive-web-design-with-css-grid-and-flexbox-2gio?1 侵害がある場合は、削除するために[email protected]に連絡してください。それ
最新のチュートリアル もっと>
  • Pythonのみを使用してフロントエンドを構築する
    Pythonのみを使用してフロントエンドを構築する
    バックエンドに重点を置く開発者にとって、フロントエンド開発は困難な、さらには悪夢のような作業になる可能性があります。私のキャリアの初期には、フロントエンドとバックエンドの境界があいまいで、誰もが両方を扱うことが期待されていました。特に CSS は絶えず苦労しました。不可能なミッションのように感じまし...
    プログラミング 2024 年 11 月 5 日に公開
  • LaravelでCronジョブを実行する方法
    LaravelでCronジョブを実行する方法
    このチュートリアルでは、Laravel で cron ジョブを実行する方法を説明しますが、何よりも生徒にとって物事をシンプルで簡単なものにします。 Laravel アプリを構築しながら、これらの自動化されたタスクを自分のコンピューター上でセットアップして実行する方法を検討していきます。 まず、cr...
    プログラミング 2024 年 11 月 5 日に公開
  • パディングはインライン要素の間隔にどのような影響を与えますか?また、競合はどのように解決できますか?
    パディングはインライン要素の間隔にどのような影響を与えますか?また、競合はどのように解決できますか?
    インライン要素のパディング: 効果と制限ソースによると、インライン要素の上部と下部にパディングを追加しても影響はありません周囲の要素の間隔。ただし、「パディングは他のインライン要素と重なる」という記述は、パディングが影響を与える特定の状況がある可能性があることを示唆しています。オーバーラップ パディ...
    プログラミング 2024 年 11 月 5 日に公開
  • Django クラスベースのビューが簡単に
    Django クラスベースのビューが簡単に
    ご存知のとおり、django は Web アプリケーション開発の設計に MVT (model-view-template) を使用します。 View 自体は、リクエストを受け取り、レスポンスを返す呼び出し可能です。 Django はクラス ベース ビューと呼ばれるものを提供するため、これは単なる機...
    プログラミング 2024 年 11 月 5 日に公開
  • VAKX を使用してノーコード AI エージェントを構築する
    VAKX を使用してノーコード AI エージェントを構築する
    If you’ve been keeping up with the AI space, you already know that AI agents are becoming a game-changer in the world of automation and customer inter...
    プログラミング 2024 年 11 月 5 日に公開
  • ここでは、jQuery Datatable でカーソルベースのページネーションを実装する方法を説明します。
    ここでは、jQuery Datatable でカーソルベースのページネーションを実装する方法を説明します。
    Web アプリケーションで大規模なデータセットを操作する場合、ページネーションはパフォーマンスとユーザー エクスペリエンスにとって非常に重要です。データ テーブルで一般的に使用される標準のオフセット ベースのページネーションは、大規模なデータセットでは非効率的になる可能性があります。 カーソルベー...
    プログラミング 2024 年 11 月 5 日に公開
  • 同期エンジンが Web アプリケーションの未来となる理由
    同期エンジンが Web アプリケーションの未来となる理由
    進化する Web アプリケーションの世界では、効率、スケーラビリティ、シームレスなリアルタイム エクスペリエンスが最も重要です。従来の Web アーキテクチャは、クライアント/サーバー モデルに大きく依存しており、応答性と同期に対する現代の要求の下では困難になる可能性があります。ここで同期エンジンが...
    プログラミング 2024 年 11 月 5 日に公開
  • Python によるコンピューター ビジョンの概要 (パート 1)
    Python によるコンピューター ビジョンの概要 (パート 1)
    注: この投稿では、わかりやすくするためにグレースケール画像のみを使用します。 画像とは何ですか? 画像は値の行列として考えることができ、各値はピクセルの強度を表します。画像形式には主に 3 つのタイプがあります: Binary: この形式の画像は、0 (黒) と 1 (白) の値を...
    プログラミング 2024 年 11 月 5 日に公開
  • ウェブサイトのHTMLコード
    ウェブサイトのHTMLコード
    航空関連のウェブサイトを構築しようとしています。 AI を使用してコードを生成し、Web サイト全体を生成できるかどうかを確認したかっただけです。 HTML Web サイトはブログと互換性がありますか? それとも JavaScript を使用する必要がありますか?これがデモとして使用したコードです。...
    プログラミング 2024 年 11 月 5 日に公開
  • プログラマーのように考える: Java の基礎を学ぶ
    プログラマーのように考える: Java の基礎を学ぶ
    この記事では、Java プログラミングの基本的な概念と構造を紹介します。変数とデータ型の紹介から始まり、演算子と式、および制御フロー プロセスについて説明します。次に、メソッドとクラスについて説明し、次に入出力操作を紹介します。最後に、この記事では、給与計算の実際の例を通じて、これらの概念の適用を示...
    プログラミング 2024 年 11 月 5 日に公開
  • PHP GD は 2 つの画像の類似性を比較できますか?
    PHP GD は 2 つの画像の類似性を比較できますか?
    PHP GD は 2 つの画像の類似性を判断できますか?検討中の質問は、次の方法を使用して 2 つの画像が同一であるかどうかを確認できるかどうかを尋ねます。 PHP GD の違いを比較します。これには、2 つの画像の差を取得し、画像全体が白 (または均一な色) で構成されているかどうかを判断する必要...
    プログラミング 2024 年 11 月 5 日に公開
  • これらのキーを使用して上級レベルのテストを作成します (JavaScript でのテスト要求)
    これらのキーを使用して上級レベルのテストを作成します (JavaScript でのテスト要求)
    この記事では、すべての上級開発者が知っておくべき 12 のテストのベスト プラクティスを学びます。 Kent Beck の記事「Test Desiderata」は Ruby で書かれているため、実際の JavaScript の例が表示されます。 これらのプロパティは、より良いテストを作成できるように...
    プログラミング 2024 年 11 月 5 日に公開
  • matlab/octave アルゴリズムを C に移植することによる AEC への最適なソリューション
    matlab/octave アルゴリズムを C に移植することによる AEC への最適なソリューション
    終わり!自分自身に少し感動しました。 当社の製品にはエコーキャンセル機能が必要であり、考えられる技術的解決策が 3 つ特定されました。 1) MCU を使用してオーディオ信号のオーディオ出力とオーディオ入力を検出し、オプションの 2 つのチャネル切り替えの間のオーディオ出力とオーディオ入力の強度に応...
    プログラミング 2024 年 11 月 5 日に公開
  • Web ページを段階的に構築する: HTML の構造と要素を調べる
    Web ページを段階的に構築する: HTML の構造と要素を調べる
    ?今日は、私のソフトウェア開発の旅において重要なステップとなります。 ?私は最初のコード行を書き、HTML の本質を掘り下げました。対象となる要素とタグ。昨日は、Web サイトを構造化するためのボックス化テクニックを検討しました。そして今日は、ヘッダー、フッター、コンテンツ領域などのセクションを作成...
    プログラミング 2024 年 11 月 5 日に公開
  • プロジェクトのアイデアはユニークである必要はありません: その理由は次のとおりです
    プロジェクトのアイデアはユニークである必要はありません: その理由は次のとおりです
    イノベーションの世界では、プロジェクトのアイデアが価値があるためには革新的であるか、完全にユニークである必要があるという誤解がよくあります。しかし、それは真実とは程遠いです。私たちが今日使用している成功した製品の多くは、主要な機能セットを競合他社と共有しています。彼らを区別するのは必ずしもアイデアで...
    プログラミング 2024 年 11 月 5 日に公開

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3