検索
ホームページウェブフロントエンドhtmlチュートリアルHTML と CSS を使用してウォーターフォール フロー カード レイアウトを実装する方法

HTML と CSS を使用してウォーターフォール フロー カード レイアウトを実装する方法

HTML と CSS を使用してウォーターフォール フロー カード レイアウトを実装する方法

Web 開発では、ウォーターフォール フロー カード レイアウトは一般的で優れた表示方法です。ウォーターフォール フロー レイアウトはカードの不規則な形状が特徴で、コンテンツの量と画面サイズに応じて高さと位置が自動的に調整され、ページがより魅力的でインタラクティブになります。この記事では、HTML と CSS を使用してウォーターフォール フロー カード レイアウトを実装する方法を紹介し、具体的なコード例を示します。

1. HTML 構造
まず、HTML 構造を作成する必要があります。この例では、複数のカードを含むコンテナを使用します。各カードには画像とテキストが含まれます。以下のコードを見てください:

<div class="container">
  <div class="card">
    <img src="/static/imghwm/default1.png"  data-src="image1.jpg"  class="lazy" alt="Image 1">
    <p>Lorem ipsum dolor sit amet.</p>
  </div>
  <div class="card">
    <img src="/static/imghwm/default1.png"  data-src="image2.jpg"  class="lazy" alt="Image 2">
    <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit.</p>
  </div>
  <div class="card">
    <img src="/static/imghwm/default1.png"  data-src="image3.jpg"  class="lazy" alt="Image 3">
    <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</p>
  </div>
  <!-- 添加更多的卡片 -->
</div>

2. CSS スタイル

次に、ウォーターフォール フロー カード レイアウトを実装するために CSS スタイルを追加する必要があります。まず、コンテナの幅を設定し、その内部要素をフローティングにする必要があります。カードの幅と間隔も設定する必要があります。以下のコードを見てください:

.container {
  width: 90%;
  margin: 0 auto;
}

.card {
  width: 300px;
  margin-bottom: 20px;
  float: left;
}

次に、ウォーターフォール効果を実現するために詳細スタイルを追加する必要があります。 CSS の column-count プロパティと column-gap プロパティを使用して列を作成し、break-inside プロパティを使用して各カードを独立して表示できます。さらに、CSS の transform プロパティを使用してアニメーション効果を追加することもできます。以下のコードを見てください:

.container {
  column-count: 3;
  column-gap: 20px;
}

.card {
  break-inside: avoid;
  transform: translateY(0);
  transition: transform .3s ease-in-out;
}

.card:hover {
  transform: translateY(-10px);
}

これらのスタイルは 3 列のウォーターフォール レイアウトを作成し、マウスオーバーで上向きのアニメーションを生成します。必要に応じて調整およびカスタマイズできます。

3. JavaScript 拡張機能

上記の方法では単純なウォーターフォール フロー レイアウトを実現できますが、より複雑なレイアウト要件の場合は、それを実現するために JavaScript を使用する必要がある場合があります。たとえば、ページが読み込まれるときに、JavaScript を使用してカードの位置と高さを動的に計算して設定できます。以下は、JavaScript を使用してウォーターフォール フロー レイアウトを実装する簡単な例です。

window.addEventListener('load', function() {
  var container = document.querySelector('.container');
  var columnCount = 3;
  var columnHeight = [];

  // 初始化列高度
  for (var i = 0; i < columnCount; i++) {
    columnHeight[i] = 0;
  }

  Array.from(container.children).forEach(function(card) {
    // 找到最小高度的列
    var minHeight = Math.min.apply(null, columnHeight);
    var columnIndex = columnHeight.indexOf(minHeight);

    // 设置卡片的位置
    card.style.left = columnIndex * (card.offsetWidth + 20) + 'px';
    card.style.top = minHeight + 'px';

    // 更新列高度
    columnHeight[columnIndex] += card.offsetHeight + 20;
  });
});

この例では、最初にコンテナ要素とカード要素を取得し、次に Array.from メソッドを使用してコンテナに要素を追加します。 子要素は配列に変換されます。次に、ループを使用してカードの位置と高さを計算し、列の高さを更新することで適応型ウォーターフォール レイアウトを実装します。

概要

HTML、CSS、およびいくつかの JavaScript コードを使用すると、ウォーターフォール フロー カード レイアウトを簡単に作成できます。上記の例は、独自のニーズに応じて変更および拡張できる基本的な実装方法を示しています。この記事がウォーターフォール フロー レイアウトの実装方法を理解するのに役立つことを願っています。

以上がHTML と CSS を使用してウォーターフォール フロー カード レイアウトを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
テキストからウェブサイトへ:HTMLの力テキストからウェブサイトへ:HTMLの力Apr 13, 2025 am 12:07 AM

HTMLは、Webページを構築するために使用される言語であり、タグと属性を使用してWebページの構造とコンテンツを定義します。 1)htmlは、などのタグを介してドキュメント構造を整理します。 2)ブラウザはHTMLを分析してDOMを構築し、Webページをレンダリングします。 3)マルチメディア関数を強化するなど、HTML5の新機能。 4)一般的なエラーには、閉じられていないラベルと引用されていない属性値が含まれます。 5)最適化の提案には、セマンティックタグの使用とファイルサイズの削減が含まれます。

HTML、CSS、およびJavaScriptの理解:初心者向けガイドHTML、CSS、およびJavaScriptの理解:初心者向けガイドApr 12, 2025 am 12:02 AM

webdevelopmentReliesOnhtml、css、andjavascript:1)htmlStructuresContent、2)cssStylesit、および3)Javascriptaddsinteractivity、形成、

HTMLの役割:Webコンテンツの構造HTMLの役割:Webコンテンツの構造Apr 11, 2025 am 12:12 AM

HTMLの役割は、タグと属性を使用してWebページの構造とコンテンツを定義することです。 1。HTMLは、読みやすく理解しやすいようなタグを介してコンテンツを整理します。 2。アクセシビリティとSEOを強化するには、セマンティックタグなどを使用します。 3. HTMLコードの最適化により、Webページの読み込み速度とユーザーエクスペリエンスが向上する可能性があります。

HTMLとコード:用語を詳しく見るHTMLとコード:用語を詳しく見るApr 10, 2025 am 09:28 AM

htmlisaspecifictypeofcodefocuseduructuringwebcontent

HTML、CSS、およびJavaScript:Web開発者に不可欠なツールHTML、CSS、およびJavaScript:Web開発者に不可欠なツールApr 09, 2025 am 12:12 AM

HTML、CSS、およびJavaScriptは、Web開発の3つの柱です。 1。HTMLは、Webページ構造を定義し、などなどのタグを使用します。2。CSSは、色、フォントサイズなどのセレクターと属性を使用してWebページスタイルを制御します。

HTML、CSS、およびJavaScriptの役割:コアの責任HTML、CSS、およびJavaScriptの役割:コアの責任Apr 08, 2025 pm 07:05 PM

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTMLは初心者のために簡単に学ぶことができますか?HTMLは初心者のために簡単に学ぶことができますか?Apr 07, 2025 am 12:11 AM

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用​​できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

HTMLでの開始タグの例は何ですか?HTMLでの開始タグの例は何ですか?Apr 06, 2025 am 12:04 AM

Anexampleapalofastartingtaginhtmlis、それはaperginsaparagraph.startingtagsaresentionentientiontheyinitiateelements、definetheirtypes、およびarecrucialforurturingwebpagesandcontingthomedomを構築します。

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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター