[JS]デモがバツグンにかっこいい!さまざまな要素がビューポートに表示される時にエフェクトを与えるスクリプト -onScreen
Post on:2013年11月7日
ブログのように記事のサムネイルを縦長に配置したり、画像ギャラリーのように画像を垂直・水平に配置したり、ブラウザの表示範囲外の要素を水平・垂直スクロールで表示する時にちょっと素敵なエフェクトを加えるjQueryのプラグインを紹介します。
ユーザー全員が気がつくエフェクトではないですが、こーゆの好物です。
data:image/s3,"s3://crabby-images/2334d/2334d648e0a988ccd3ea9c4c5796975ea74491f0" alt="サイトのキャプチャ"
onScreenのデモ
4種類のデモが楽しめます。
data:image/s3,"s3://crabby-images/ae857/ae857e8310eff51960a7bd83c78755d30dea7abe" alt="サイトのキャプチャ"
この4つのサークルの表示もかっこいいw
data:image/s3,"s3://crabby-images/bdfff/bdfff83b493e50a34a7f902efdd8b9c06cc53c33" alt="デモのキャプチャ"
ページの下部にスクロールすると、ビューポートに入ってくる要素をアニメーションで表示します。
data:image/s3,"s3://crabby-images/76908/769087b362f6f968d3384a46584ae4d004663948" alt="デモのキャプチャ"
下部で、ちょうどアニメーション化しているキャプチャです。
data:image/s3,"s3://crabby-images/a6df4/a6df4dabbe6173ab3eef4736f10c569f22760940" alt="デモのキャプチャ"
Lazy Loadは画像を遅延表示するエフェクトで、今までに紹介したのとは一味違った感じです。
data:image/s3,"s3://crabby-images/555f5/555f5ffc5a2be16c366c0d9b92b01468fb42e719" alt="デモのキャプチャ"
一つ目のデモ「Append New Elements」の水平版ですが、右から要素がフェードインしてアニメーションします。
data:image/s3,"s3://crabby-images/ee085/ee0858ccda65d6827ddfb8490a9dfab94ed5e673" alt="デモのキャプチャ"
onScreenはさまざまなDOM要素に対応しており、パラグラフ、画像、コンテンツスライダーなどスクロールが可能な要素全てに利用できます。
スクロールして表示する際に、ちょっとだけCSSのエフェクトを加えるのかっこいいですね。
onScreenの使い方
Step 1: 外部ファイル
jquery.jsと当スクリプトを外部ファイルとして記述します。
<head> ... <script type="text/javascript" src="lib/jquery-1.10.2.min.js"></script> <script type="text/javascript" src="lib/jquery.onscreen.min.js"></script> </head>
Step 2: HTML
onScreenを適用するエレメントは指定できるようにclassやidを付与します。
<section class="posts"> <article class="post">記事</article> </section>
Step 3: JavaScript
適用する要素をjQueryのセレクタで指定し、スクリプトを実行します。
$('article.post').onScreen({});
スクリプトのオプションでは、コンテナの指定、方向、遅延時の表示画像、in時out時のエフェクトなどを設定できます。
$('elements').onScreen({ container: window, direction: 'vertical', doIn: function() { // Do something to the matched elements as they come in }, doOut: function() { // Do something to the matched elements as they get off scren }, tolerance: 0, toggleClass: true, lazyAttr: null, lazyPlaceholder: 'someImage.jpg', debug: false });
sponsors