ウォーターフォールコード実装(絶対位置決め)_html/css_WEB-ITnose
ウォーターフォールフローは、ページ表示において非常に一般的なレイアウト方法です。このレイアウトを使用すると、Web ページは非常に美しく見えます。滝の流れ要素の最大の特徴は、幅が等しく、高さが不等であることです。滝の流れを実現する方法を段階的に分析してみましょう。
1. まず、いくつかの画像を用意し、基本的な html+css コードを記述します (この手順は非常に簡単なので、コードを直接貼り付けます)。
- 初期ページ効果
pic1.png
- Web ページの構造
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>瀑布流</title><link rel="stylesheet" href="index.css"></head><body><div class="container"> <div class="box"> <div class="box-img"> <img src="img1.jpg" alt="pic1"> </div> </div> <div class="box"> <div class="box-img"> <img src="img2.jpg" alt="pic2"> </div> </div> <div class="box"> <div class="box-img"> <img src="img3.jpg" alt="pic3"> </div> </div> <div class="box"> <div class="box-img"> <img src="img4.jpg" alt="pic4"> </div> </div> <div class="box"> <div class="box-img"> <img src="img5.jpg" alt="pic5"> </div> </div> <div class="box"> <div class="box-img"> <img src="img6.jpg" alt="pic6"> </div> </div></div></body></html>
ログイン後にコピー
- css
*{margin: 0;padding: 0;}.container{position: relative;width: 1040px;margin: 0 auto;}.box{float: left;padding: 5px;font-size: 0;}.box-img img{width: 250px;}
ログイン後にコピー
2. ウォーターフォールフロー効果の実装
原理:1.根据所设的宽度,获得每一行可以放几列(我的列子中是写死的,一行放4列);2.获取每个元素的高度,保存在数组中;3.从第一个元素依次设置每个元素的定位: 3.1 先获得这个元素该放在第几列(现有高度最小的列),通过下面的getMinHeightCol函数; 3.2 根据每列的宽以及每列的当前高度,设置元素的left,top值(当然也要设置position:absolute); 3.3 重新修改每列的当前高度(为了3.1获得最新的“高度最小的列”);
- js コード (jquery に依存)
$(function(){ var elesHeight = [];//每个元素的宽度 var colsHeight = [0,0,0,0]; //每列元素现有的高度 $(".container .box").each(function(index,item){ var eleHeight = $(this).height(); elesHeight.push(eleHeight); }); //依次摆放每一个元素 $(".container .box").each(function(index,item){ //获得该元素应该在第几列 var colShould = getMinHeightCol(colsHeight); var tempTop = colsHeight[colShould]; var tempLeft = colShould*260; $(this).css({"position":"absolute","top":tempTop+"px",left:tempLeft+"px"}); //同时将该列的高度加上当前新增元素的高度 colsHeight[colShould] += $(this).height(); }); //得到四列中高度最小的那一列 function getMinHeightCol(arr){ var minHeight = Math.min.apply(null, arr); console.log("最小高度:"+minHeight); for(var i in arr){ if(arr[i]==minHeight){ return i; } } //默认第一列 return 0; }});
- ページ効果
pic2.png
上記は単純なウォーターフォール フローの実装であり、完全なウォーターフォール フローです次の機能も必要です:
- ページの幅と各列の幅に基づいて列数が自動的に計算されます。
- ウィンドウ サイズが変更されると、位置が変更されます。要素のレイアウトが再計算されます。
- 解決策 - ウィンドウ サイズが急速に変化すると、イベントが継続的にトリガーされ、大量のパフォーマンスの消費が発生します。
针对第三个问题的setTimeout解决方法:窗口变化之后开始计时,如果窗口还在变换则从新开始计时,窗口不再变化则延时(很短的时间)触发重排事件。var re;window.onresize = function() { clearTimeout(re); re = setTimeout(resize,100); };
ログイン後にコピー
残りの最適化を自分で試してみてください~

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック

この記事では、HTML&lt; Progress&gt;について説明します。要素、その目的、スタイリング、および&lt; meter&gt;との違い要素。主な焦点は、&lt; Progress&gt;を使用することです。タスクの完了と&lt; Meter&gt; statiの場合

この記事では、HTML&lt; Datalist&GT;について説明します。オートコンプリートの提案を提供し、ユーザーエクスペリエンスの改善、エラーの削減によりフォームを強化する要素。

この記事では、html&lt; meter&gt;について説明します。要素は、範囲内でスカラーまたは分数値を表示するために使用され、Web開発におけるその一般的なアプリケーション。それは差別化&lt; Meter&gt; &lt; Progress&gt;およびex

この記事では、モバイルデバイスのレスポンシブWebデザインに不可欠なViewportメタタグについて説明します。適切な使用により、最適なコンテンツのスケーリングとユーザーの相互作用が保証され、誤用が設計とアクセシビリティの問題につながる可能性があることを説明しています。

この記事では、ブラウザのユーザー入力を直接検証するために、必要、パターン、MIN、MAX、および長さの制限などのHTML5フォーム検証属性を使用して説明します。

この記事では、html5&lt; time&gt;について説明します。セマンティックデート/時刻表現の要素。 人間の読み取り可能なテキストとともに、マシンの読みやすさ(ISO 8601形式)のDateTime属性の重要性を強調し、Accessibilitを増やします

記事では、HTML5クロスブラウザーの互換性を確保するためのベストプラクティスについて説明し、機能検出、プログレッシブエンハンスメント、およびテスト方法に焦点を当てています。

この記事では、&lt; iframe&gt;外部コンテンツをWebページ、その一般的な用途、セキュリティリスク、およびオブジェクトタグやAPIなどの代替案に埋め込む際のタグの目的。
