0%

Programmingプログラミングナレッジ

Posted:2018.09.23

jQueryでスクロールに連動するアニメーションをプラグインなしで実装する

スクロールに連動した動きにパララックスがありますが、最近は要素に動きのアニメーションをつけたりと、より複雑でバリエーションが増えてきているようになりました。今回はjQueryを使って、要素をスクロールに合わせて動かすアニメーションを実装していきたいと思います。

 

このような機能のプラグインはたくさんありますが、ここではプラグインを使わない方法での実装になります。シンプルな動きであればプラグインなしでも充分対応できます。

 

今回の要件は、スクロールを進めていき画面内に要素が表示されるタイミングでアニメーションが始まるという仕様になります。では早速コードを見ていきます。

【HTML】※一部省略

<body>
  <section>
    <div class="scroll-animation-obj scroll-animation-hop">下から浮かび上がるアニメーション
    </div>
  </section>
  <section>
    <div class="scroll-animation-obj scroll-animation-left">左からスライドインで表示されるアニメーション
    </div>
  </section>
  <section>
    <div class="scroll-animation-obj scroll-animation-right">右からスライドインで表示されるアニメーション
    </div>
  </section>
</body>

 

【CSS】

.scroll-animation-obj {
  opacity: 0;
  transition: all 0.5s ease 0.5s;
}
.scroll-animation-hop {
  transform: translate(0,60px);
}
.scroll-animation-left {
  transform: translate(-120px,0);
}
.scroll-animation-right {
  transform: translate(120px,0);
}

 

HTMLの要素にそれぞれclassを当てておきます。対象となる要素には全て、opacityをゼロにして、transitionが設定されたclassをつけておきます。また、アニメーションの初期化として、それぞれCSSで設定しておきます。この値を調整することでいろんな動きが表現できます。続いてjQueryで動きをつけていきます。

 

【javascript】

const obj = $(".scroll-animation-obj");
const hopIn = $(".scroll-animation-hop");
const leftIn = $(".scroll-animation-left");
const rightIn = $(".scroll-animation-right");
$(window).on('scroll',function(){
  obj.each(function(){
    const objPos = $(this).offset().top;
    const scroll = $(window).scrollTop();
    const windowH = $(window).height();
    if(scroll > objPos - windowH){
      $(this).css({
        'opacity': '1'
      });
    } else {
      $(this).css({
        'opacity': '0'
      });
    }
  });
  hopIn.each(function(){
    const objPos = $(this).offset().top;
    const scroll = $(window).scrollTop();
    const windowH = $(window).height();
    if(scroll > objPos - windowH){
      $(this).css({
        'transform': 'translate(0,0)'
      });
    } else {
      $(this).css({
        'transform': 'translate(0,60px)'
      });
    }
  });
  leftIn.each(function(){
    const objPos = $(this).offset().top;
    const scroll = $(window).scrollTop();
    const windowH = $(window).height();
    if(scroll > objPos - windowH){
      $(this).css({
        'transform': 'translate(0,0)'
      });
    } else {
      $(this).css({
        'transform': 'translate(-120px,0)'
      });
    }
  });
  rightIn.each(function(){
    const objPos = $(this).offset().top;
    const scroll = $(window).scrollTop();
    const windowH = $(window).height();
    if(scroll > objPos - windowH){
      $(this).css({
        'transform': 'translate(0,0)'
      });
    } else {
      $(this).css({
        'transform': 'translate(120px,0)'
      });
    }
  });
});

 

javascript側ではスクロールのイベントでアニメーションの関数を作成していきます。基本的にはどのアニメーションも同じ形になります。現在のページップからのスクロール量と対象となる要素の座標を取得して、要素がウィンドウ内まで表示されるようになった時にCSSで動かしていくという形になります。

 

いかがでしょうか、シンプルですがこれだけで意外と本格的なスクロールアニメーションが実装できます。今回のサンプルはこちらにあげていますので参考にどうぞ。

 

See the Pen simple animation with scroll by designsupply (@designsupply) on CodePen.

 


 

より複雑な動きやカスタマイズ性を求めるならばプラグインを導入するのも選択肢に入ってきますが、限定的な箇所で実装する場面であれば、じゅうぶん役に立つのではないでしょうか。

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

こんな記事も読まれています

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】