検索
ホームページウェブフロントエンドCSSチュートリアルCSS での聖杯レイアウトとダブルフライング ウイング レイアウトの紹介 (コード付き)

CSS での聖杯レイアウトとダブルフライング ウイング レイアウトの紹介 (コード付き)

Aug 02, 2018 am 10:40 AM
css両翼レイアウト聖杯のレイアウトレイアウト

この記事はCSSでの聖杯レイアウトと二重飛行翼レイアウトを紹介しています。必要な方は参考にしていただければ幸いです。

聖杯レイアウト

CSS での聖杯レイアウトとダブルフライング ウイング レイアウトの紹介 (コード付き)

<div>#header</div>

  <div>
    <div>#center</div>
    <div>#left</div>
    <div>#right</div>
  </div>

  <div>#footer</div>

達成される効果は主にコンテナ内であり、左と右の幅は固定されており、中央が最初にレンダリングされ、幅は適応的です。

    body {
      min-width: 500px;
    }
    #container {
      overflow: auto;        /* BFC */
      padding-left: 180px;
      padding-right: 150px;
    }
    #container .column {
      height: 200px;
      position: relative;
      float: left;
    }
    #center {
      background-color: #e9e9e9;
      width: 100%;
    }
    #left {
      background-color: red;
      width: 180px;
      right: 180px; 
      margin-left: -100%
    }
    #right {
      background-color: blue;
      width: 150px; 
      margin-right: -150px;
    }

    #header, 
    #footer {
      background-color: #c9c9c9;
    }

このソリューションで注意すべき点がいくつかあります:

  1. 中央の要素は左右の前に配置されているため、中央が最初にレンダリングされ、ユーザーはページのメイン コンテンツを最初に見ることができます。

  2. コンテナ (幅:100%) は、コンテンツの 3 列をラップし、padding-left と padding-right によって左右の列用のスペースを作成します。

  3. center、left、rightはすべて左float(float:left)を設定しているため、コンテナ内にはfloat flowが存在します。

  4. 左の要素に margin-left: -100% を設定すると、左はコンテナの左上隅に移動し、position: right: 180px を渡します。 、コンテナの左パディング位置に移動します。 margin-left: -100%,使得left移动到container的左上角,在通过position:relative; right: 180px,移动到container的padding-left的位置上去。

  5. 给right 元素设置 margin-right: -150px,使得它移动到container的padding-right的位置上去。

ps: margin-left 和 margin-right 利用了浮动流的特性,使得第一行能够同时容纳center,left,right这三个元素。

圣杯布局(flexbox实现)

CSS での聖杯レイアウトとダブルフライング ウイング レイアウトの紹介 (コード付き)

  <div>#header</div>   <div>     <div>#center</div>     <div>#left</div>     <div>#right</div>   </div>   <div>#footer</div>
    body {
      min-width: 550px;  
    }
    #HolyGrail {
      display: flex;
      min-height: 100vh;
      flex-direction: column;
    }
    #container {
      display: flex;
      flex: 1;
    }
    #center {
      background-color: #e9e9e9;
      flex: 1;
    }
    #left {
      background-color: red;
      order: -1;
      width: 150px;
    }
    #right {
      background-color: blue;
      width: 150px;
    }
    #header, 
    #footer {
      height: 50px;
      background-color: #c9c9c9;
    }

如果不考虑ie10及以下的浏览器,那么可以使用flex来实现圣杯布局。而且圣杯布局可以通过让container填充高度来使得footer达到一个sticky的效果。
flex兼容性

双飞翼布局

CSS での聖杯レイアウトとダブルフライング ウイング レイアウトの紹介 (コード付き)

圣杯布局和双飞翼布局解决的问题是一样的,就是两边定宽,中间自适应的三栏布局,中间栏要在放在文档流前面以优先渲染。圣杯布局和双飞翼布局解决问题的方案在前一半是相同的,也就是三栏全部float浮动,但左右两栏加上负margin让其跟中间栏p并排,以形成三栏布局。不同的地方在于解决中间p内容不被遮挡的思路上面

  1. 圣杯布局的为了中间内容不被修改,是通过包裹元素的padding-leftpadding-right来使得内容p置于中间,然后再通过相对定位position:relative,配合right或left属性让左右两栏不则当中间内容。

  2. 双飞翼布局的解决方案是:通过再中间元素的内部新增一个p用于放置内容,然后通过左右外边距margin-leftmargin-right

  3. 右側の要素に margin-right: -150px を設定して、コンテナのpadding-rightの位置に移動するようにします。

  4. ps: margin-left と margin-right はフローティング フローの特性を利用しているため、最初の行は中央、左、右の 3 つの要素を同時に収容できます。
聖杯レイアウト (フレックスボックス実装)

CSS での聖杯レイアウトとダブルフライング ウイング レイアウトの紹介 (コード付き)

<div>#header</div>

  <div>
    <div>
      <div>#center</div>
    </div>
    <div>#left</div>
    <div>#right</div>
  </div>

  <div>#footer</div>
    body {
      min-width: 500px;  
    }
    #container {
      overflow: auto;        /* BFC */
    }
    #container .column {
      height: 200px;
      float: left;
    }
    #center {
      background-color: #e9e9e9;
      width: 100%;
    }
    #center-content {
      margin-left: 180px;
      margin-right: 150px;
    } 
    #left {
      width: 180px;
      background-color: red;
      margin-left: -100%;
    }
    #right {
      background-color: blue;
      width: 150px;  
      margin-left: -150px; 
    }

    #header, 
    #footer {
      background-color: #c9c9c9;
    }
ブラウザー IE10 以下を考慮しない場合は、flex を使用して Holy Grail レイアウトを実装できます。また、Holy Grail レイアウトでは、コンテナーが高さいっぱいになるようにすることで、フッターに粘着効果を与えることができます。
フレックス互換性

ダブルフライングウィングレイアウト

🎜CSS での聖杯レイアウトとダブルフライング ウイング レイアウトの紹介 (コード付き)🎜🎜🎜聖杯レイアウトと二重飛行翼レイアウトによって解決される問題は同じであり、両側に固定幅と適応型中央を備えた 3 列レイアウトです。中央の列はドキュメント フローに配置する必要があります。前面が最初にレンダリングされます。聖杯レイアウトとダブルウィングレイアウトの問題の解決策は前半は同じです。つまり、3 つの列はすべてフロートですが、左右の列にマイナスのマージンを追加して並べて表示します。中央の列 p を使用して 3 列のレイアウトを形成します。 🎜違いは、🎜中央の p コンテンツがブロックされないように解決するという考え方にあります 🎜🎜🎜🎜Holy Grail レイアウトは、要素をラップするために padding-leftpadding を使用します。中央のコンテンツが変更されないようにするには、 -right を使用してコンテンツ p を中央に配置し、相対位置指定 position:relative を使用して、 right または left 属性を使用します。左側と右側の列を中央のコンテンツにしないでください。 🎜🎜🎜🎜ダブルウィングレイアウトの解決策は、中央の要素内に p を追加してコンテンツを配置し、左右のマージン margin-leftmargin-right を使用することです。 左右の列のためのスペースを残しておきます。 🎜🎜🎜🎜二重飛行翼レイアウトには p タグが 1 つ増え、使用する CSS 属性が 4 つ減りました。左と右の p は相対的なレイアウト位置を使用するため、padding-left と padding-right の使用が少なくなり、margin-left と margin-right の使用が多くなります。 🎜🎜🎜rrreeerrreee🎜 おすすめ関連記事: 🎜🎜🎜CSSでフローティング要素の行折り返しを実装する方法🎜🎜🎜🎜 CSSでのグリッドレイアウトの使い方まとめ(コード付き)🎜🎜

以上がCSS での聖杯レイアウトとダブルフライング ウイング レイアウトの紹介 (コード付き)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
CSSグリッドとは何ですか?CSSグリッドとは何ですか?Apr 30, 2025 pm 03:21 PM

CSSグリッドは、複雑で応答性の高いWebレイアウトを作成するための強力なツールです。設計を簡素化し、アクセシビリティを向上させ、古い方法よりも多くの制御を提供します。

CSS Flexboxとは何ですか?CSS Flexboxとは何ですか?Apr 30, 2025 pm 03:20 PM

記事では、レスポンシブデザインにおけるスペースの効率的なアラインメントと分布のためのレイアウト方法であるCSS FlexBoxについて説明します。 FlexBoxの使用量を説明し、CSSグリッドと比較し、ブラウザのサポートを詳細に説明します。

CSSを使用してWebサイトを応答するにはどうすればよいですか?CSSを使用してWebサイトを応答するにはどうすればよいですか?Apr 30, 2025 pm 03:19 PM

この記事では、ビューポートメタタグ、柔軟なグリッド、流体メディア、メディアクエリ、相対ユニットなど、CSSを使用してレスポンシブWebサイトを作成するための手法について説明します。また、CSSグリッドとフレックスボックスを使用してカバーし、CSSフレームワークを推奨しています

CSSボックスサイズのプロパティは何をしますか?CSSボックスサイズのプロパティは何をしますか?Apr 30, 2025 pm 03:18 PM

この記事では、要素の寸法の計算方法を制御するCSSボックスサイズのプロパティについて説明します。コンテンツボックス、ボーダーボックス、パディングボックスなどの値と、レイアウト設計とフォームアライメントへの影響について説明します。

CSSを使用してアニメーション化するにはどうすればよいですか?CSSを使用してアニメーション化するにはどうすればよいですか?Apr 30, 2025 pm 03:17 PM

記事では、CSS、キープロパティ、およびJavaScriptとの組み合わせを使用してアニメーションの作成について説明します。主な問題は、ブラウザの互換性です。

CSSを使用してプロジェクトに3D変換を追加できますか?CSSを使用してプロジェクトに3D変換を追加できますか?Apr 30, 2025 pm 03:16 PM

記事では、3D変換、主要なプロパティ、ブラウザの互換性、およびWebプロジェクトのパフォーマンスに関する考慮事項にCSSを使用して説明します。

CSSに勾配を追加するにはどうすればよいですか?CSSに勾配を追加するにはどうすればよいですか?Apr 30, 2025 pm 03:15 PM

この記事では、CSSグラデーション(線形、放射状、繰り返し)を使用して、ウェブサイトのビジュアルを強化し、深さ、フォーカス、および現代の美学を追加します。

CSSの擬似要素とは何ですか?CSSの擬似要素とは何ですか?Apr 30, 2025 pm 03:14 PM

記事では、CSSの擬似要素、HTMLスタイリングの強化における使用、および擬似クラスとの違いについて説明します。実用的な例を提供します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境