Masonry系の最強スクリプト、レスポンシブ対応のレイアウトが簡単に実装できる -Muuri
Post on:2016年12月22日
カードやパネルをレンガ状に配置し、ドラッグして配置をアニメーションで変更、ソートやフィルタリング機能も可能なグリッドレイアウトが簡単に実装できるスクリプトを紹介します。
マウスで操作しても、タッチデバイスで操作しても、非常に快適です。
data:image/s3,"s3://crabby-images/c10c8/c10c89306a3d1119d0ab3588c1888d1d0db604e7" alt="デモのキャプチャ"
Muuriのデモ
デモはモダンブラウザ、IE9+でご覧ください。スマホやタブレットでも動作します。
※スマホだと各パネルが大きいので、操作しにくいかも。
data:image/s3,"s3://crabby-images/d3c47/d3c4718e8db08a025c8b3c825a173c5c7abe8712" alt="デモのキャプチャ"
各パネルをドラッグすると、アニメーションで配置を変更するだけでなく、ソートやフィルタリング機能も備わっています。
data:image/s3,"s3://crabby-images/7652a/7652a16ab78214c52f883ecc57af848c21d6e093" alt="デモのキャプチャ"
機能は上部のセレクトフォーム
カラーでソートしてみました。
data:image/s3,"s3://crabby-images/a2799/a2799a32ad5fb9c468c98511523a8b1a0d56814d" alt="デモのキャプチャ"
ソート機能: カラー
面白い機能として、レイアウト方法を変更することもできます。
data:image/s3,"s3://crabby-images/5612d/5612d23c22cf512154c0477b80b1726f408fcd94" alt="デモのキャプチャ"
通常は左・上を基準にパネルを順番に配置しますが、隙間がでないことを優先にさせたり、右や下を基準にすることもできます。
data:image/s3,"s3://crabby-images/414be/414be2fb36d7ad2a4b56ed1f0fa29e718ee3b0fb" alt="デモのキャプチャ"
右・下を基準に配置
Muuriの使い方
Step 1: 外部ファイル
当スクリプトとVelocityとHamemr.jsの3つを外部ファイルとして記述します。
1 2 3 4 5 6 7 8 |
<body> ... コンテンツ ... <script src="velocity.js"></script> <script src="hammer.js"></script> <script src="muuri.js"></script> </body> |
Step 2: HTML
グリッドはdiv要素で実装し、1つのグリッドに対して最低2つ以上のアイテムが必要です。アイテムが入れ子になっているのは、外側はアイテムを配置するため、内側はアニメーションのため、となっています。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
<div class="grid"> <div class="item"> <div class="item-content"> This can be anything. </div> </div> <div class="item"> <div class="item-content"> <div class="my-custom-content"> Yippee! </div> </div> </div> </div> |
Step 3: CSS
グリッドを構成する基本となるスタイルシートです。
基本的には変更する必要はありませんが、各パネルの隙間を調整したい場合は.itemのmargin値を変更します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
.grid { position: relative; } .item { display: block; position: absolute; width: 100px; height: 100px; margin: 5px; z-index: 1; } .item.muuri-dragging, .item.muuri-releasing { z-index: 2; } .item.muuri-hidden { z-index: 0; } .item-content { position: relative; width: 100%; height: 100%; } |
Step 4: JavaScript
最後に、スクリプトを初期化して実行します。
1 2 3 4 |
var grid = new Muuri({ container: document.getElementsByClassName('grid')[0], items: document.getElementsByClassName('item') }); |
オプションなど、さらに詳しい情報は下記をご覧ください。
sponsors