[JS]Pinterestやウォールなどの最近よく見かけるカードを使ったレイアウトを作成するスクリプト -Freewall
Post on:2013年10月15日
デスクトップでもタブレットでもスマフォでも、カードを使ったさまざまなパターンのグリッドレイアウトをダイナミックに作成するjQueryのプラグインを紹介します。
data:image/s3,"s3://crabby-images/b6cab/b6caba7928154fa8223bf8022240cc9a3174619a" alt="サイトのキャプチャ"
Freewallのデモ
スクリプトのページ自体もデモになっており、さまざまなレイアウトを楽しむことができます。
data:image/s3,"s3://crabby-images/7c682/7c6823ca42b2c4def0e09fd521edca9fd783d63e" alt="デモのキャプチャ"
デモページも数多く用意されています。
data:image/s3,"s3://crabby-images/516c4/516c44e553bfd2c0ea566ce33dff3c3a59e5baca" alt="デモのキャプチャ"
まずは、ノーマルなグリッド状のレイアウト。
data:image/s3,"s3://crabby-images/72cd8/72cd82547c4604f7f26625aea6f95e18cfbd935a" alt="デモのキャプチャ"
さまざまなサイズの画像を使ったレイアウト。
以下、少しずつ高度なレイアウトになっていきます。
data:image/s3,"s3://crabby-images/daf5f/daf5f343c460fc2fd28aa127ce2fb1058be6ef74" alt="デモのキャプチャ"
各カードの高さを揃えてレイアウトします。
data:image/s3,"s3://crabby-images/4bf60/4bf60da90c26ee3941cbb7fdfb74e264df8231ff" alt="デモのキャプチャ"
スライスエンジンを使って、カードをゾーンにフィットさせます。
data:image/s3,"s3://crabby-images/54229/542292a183d8ac6ea2ed725bbb8bd623c91d31a5" alt="デモのキャプチャ"
フレキシブルなレイアウトにも対応。
data:image/s3,"s3://crabby-images/dbff1/dbff1f11e640f5be4bc1f38d98f40d57d7da3b5d" alt="デモのキャプチャ"
Pinterest風に高さの異なるカードをダイナミックにレイアウト。
Freewallの使い方
Step 1: 外部ファイル
head内にjquery.jsと当スクリプトを外部ファイルとして記述します。
<head> ... <script type="text/javascript" src="jquery-1.7.min.js"></script> <script type="text/javascript" src="freewall.js"></script> </head>
Step 2: HTML
カードを包むラッパーを用意します。
<div id="freewall" class="free-wall"> </div>
Step 3: JavaScript
デモでは、各カードをスクリプトで生成してレイアウトを作成しています。
<script type="text/javascript"> var temp = "<div class='cell' style='width:{width}px; height: {height}px; background-image: url(i/photo/{index}.jpg)'></div>"; var w = 200, h = 200, html = '', limitItem = 49; for (var i = 0; i < limitItem; ++i) { html += temp.replace(/\{height\}/g, h).replace(/\{width\}/g, w).replace("{index}", i + 1); } $("#freewall").html(html); var ewall = new freewall("#freewall"); ewall.reset({ selector: '.cell', animate: true, block: { flex: 1 }, cell: { width: 200, height: 200 }, fillGap: true, onResize: function() { ewall.fitWidth(); } }); ewall.fitWidth(); </script>
sponsors