[JS]スマホもOK!縦長ページやスライダーでコンテンツをさまざまなアニメーションで表示させるスクリプト -pageSwitch
Post on:2016年1月25日
縦長ページで次のコンテンツを表示する時、画像やテキストを配置したコンテンツスライダーで、すぅーとスライドさせたり、ぱたり、くるり、ぐい~んなど、ブラウザいっぱいのコンテンツやパネルをさまざまなアニメーションで表示させるスクリプトを紹介します。
HTMLは非常にシンプルで、スマホやタブレット、古いIEでも動作します。
スマホで、カーテンを引き上げるように表示させるのも簡単です。
data:image/s3,"s3://crabby-images/44f60/44f6087b85fa2ec28962a19738a10574afd09c63" alt="デモのキャプチャ"
pageSwitchのデモ
pageSwitchは121種類のアニメーションをサポートしており、さまざまな動きをデモページで楽しめます。
下記はブラウザ表示ですが、スマホでもタブレットでもOKです。
data:image/s3,"s3://crabby-images/fcce7/fcce7225d3e3ce8469245bd65cadd4865de2b729" alt="デモのキャプチャ"
いくつかアニメーションgifにしてみました。
data:image/s3,"s3://crabby-images/d5786/d5786d2571677a5ffa6410d1ce5bc8523d1cb86b" alt="デモのアニメーション"
パネル式の時のように半分から折れて、ぱたりと切り替わります。
操作はスクロール、ドラッグ、ホイール、矢印キーとスマホのスワイプに対応しています。
data:image/s3,"s3://crabby-images/34874/348745239800f36d80b9b07a4cdf91d7f434b658" alt="デモのアニメーション"
前のパネルに覆い被さるように切り替わります。
data:image/s3,"s3://crabby-images/7122a/7122a73318e354cae95b53464cf5e0d47df1dffd" alt="デモのアニメーション"
スライドも一味加えられたかっこいいアニメーションです。
data:image/s3,"s3://crabby-images/40c9a/40c9aeada9e64463232299069476da7791988f67" alt="デモのアニメーション"
3Dも充実しており、他にも斜めに倒れてスライドして合体するのなど、かっこいいのが揃っています。
アニメーションの一覧です。
data:image/s3,"s3://crabby-images/2d437/2d4376b2ad64e99736f38e05df6890756383ca79" alt="デモのキャプチャ"
エフェクトの種類
ブラウザいっぱいのコンテンツにも対応しており、デスクトップでもスマホでもタブレットでも楽しめます。
data:image/s3,"s3://crabby-images/c6c5a/c6c5ab3babc44d8cd2f3016dffa070ad413afe09" alt="デモのキャプチャ"
pageSwitchの使い方
Step 1: 外部ファイル
当スクリプトを外部ファイルとして記述します。
1 |
<script type="text/javascript" src="src/pageSwitch.js"></script> |
jQueryやZeptoのプラグインとしても動作します。
1 2 |
<script type="text/javascript" src="jquery.min.js"></script> <script type="text/javascript" src="src/pageSwitch.js"></script> |
Step 2: HTML
各パネルはdiv要素で実装し、それらを内包するラッパーにidを付与します。
div内は画像だけでなく、さまざまな要素を配置したコンテンツでもOKです。
1 2 3 4 5 6 7 |
<div id="imgs"> <div><img src="1.jpg" alt="画像"></div> <div><img src="2.jpg" alt="画像"></div> <div><img src="3.jpg" alt="画像"></div> <div><img src="4.jpg" alt="画像"></div> <div><img src="5.jpg" alt="画像"></div> </div> |
Step 3: JavaScript
ラッパーのIDを指定して、スクリプトを実行します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
var pw=new pageSwitch('imgs',{ duration:600, //時間 direction:1, //方向、0:横、1:縦 start:0, //スタートのパネル loop:false, //ループの有無 ease:'ease', //イージング transition:'slide', //エフェクトの種類 freeze:false, //凍結画面の有無 mouse:true, //マウス操作の有無 mousewheel:false, //マウスのホイール操作の有無 arrowkey:false, //矢印キーでの操作の有無 autoplay:false, //自動再生の有無 interval:int //新しいスライドショーの間隔 }); |
jQuery/Zepto使用時は、下記のように記述します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
$.fn.extend({ pageSwitch:function(cfg){ this[0].ps=new pageSwitch(this[0],cfg); return this; }, ps:function(){ return this[0].ps; } }); $(container_id).pageSwitch({ duration:1000, transition:'slide' }); $(container_id).ps().next(); |
sponsors