シングルページで紙芝居のような画面遷移をさせる方法

シングルページで紙芝居のような画面遷移をさせる方法:


紙芝居のような画面遷移をさせる

シングルページで紙芝居のような画面遷移するWebサイトを作成しようと思った時にちょっと行き詰まったので、解決方法を備忘録として説明します。


仕上がりイメージ



ezgif-1-434688a4065b.gif



完成コード

<style> 
  body { 
    margin: 0; 
  } 
  .frame { 
    overflow: hidden; 
  } 
  .page { 
    border: 1px solid gray; 
  } 
  .page1 { 
    background: rgb(240, 190, 190); 
  } 
  .page2 { 
    background: rgb(240, 210, 210); 
  } 
  .page3 { 
    background: rgb(240, 230, 230); 
  } 
</style> 
<body> 
  <div class="frame"> 
    <div class="page page1">page1</div> 
    <div class="page page2">page2</div> 
    <div class="page page3">page3</div> 
  </div> 
 
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> 
  <script> 
    $(function(){ 
      //ページの高さをwindowサイズに合わせる 
      $(".frame, .page").css("height", $(window).height()); 
 
      var page = 0; 
      var pages = $(".page").get(); 
      var target = 0; 
 
      $(document).click(function(){ 
        if(page < pages.length - 1){ 
          page += 1; 
          target += $(pages[page]).offset().top; 
        }else { 
          page = 0; 
          target = 0; 
        } 
        $(".frame").animate({scrollTop:target}, 400, "swing"); 
      }); 
    }); 
  </script> 
</body> 


ちょっと補足

.frame { 
  overflow: hidden; 
} 
frame要素が1ページのみを表示するための枠になっており、overflow: hidden;を適用することでユーザーがスクロールで他のページへ移動できないようにしています。

animationを使うことで、画面をクリックした際にページが遷移するようになっています。

-------✂︎----------------------------✂︎--------------

ご指摘などあれば↓までご連絡ください。
@yokuneru

コメント

このブログの人気の投稿

投稿時間:2021-06-17 22:08:45 RSSフィード2021-06-17 22:00 分まとめ(2089件)

投稿時間:2021-06-20 02:06:12 RSSフィード2021-06-20 02:00 分まとめ(3871件)

投稿時間:2021-06-17 05:05:34 RSSフィード2021-06-17 05:00 分まとめ(1274件)