JavaScriptの実装では、トップの結果を返します。

トップ淘宝網の模造効果

要件:ボタンの上部一定の位置に固定された特定の位置サイドバーにスクロールバーの表示に戻り、そして特定の位置まで後退。動的にボタンをスライド上にページの最上部をクリックして、速度が遅いために、高速からアップスライド。

アイデア:

1、ページはjsのコードを実行するためにロードされました

  JSコードは、最もに書き込むことができる(この例では、これが有する上部バックです)

  トップには、以下の2つの書き込みに使用することができます。

      ①window.onload=関数(){...}

   ②window.addEventListener( '負荷'、関数(){...})

2、要素が使用する必要があります取得

3、結合事象はスクロールをスクロール

  ロールバナーが固定された状態のサイドバーになっていることと、ユーザーモジュール

1  IF(window.pageYOffset> = bannerTop){     // window.pageYOffset画面がから巻き上げられる
2      「固定」sliderbar.style.position =;    // ときにユーザモジュールロールバナーが固定された状態のサイドバーとなります
3      sliderbar.style.top sliderbarTop + = 'PX' ; 
 4 } {
 5。      sliderbar.style.position = '絶対' ;
 6      sliderbar.style.top = '300ピクセルによって' ;
 7 }

  ときに、ユーザディスプレイモジュールの主ロールトップボタン

1  IF(window.pageYOffset> = MAINTOP){     // とき表示ボタントップユーザモジュールメインロール
2      goBack.style.display = 'ブロック' ;
 3 } {
 4。      goBack.style.display = 'なし' 5 }

4、バインドクリックイベントをクリック

  ページが動的なスライドトップのトップに戻ります]ボタンをクリックした後、遅いの速いからスピードアップスライド

1 sliderbar.addEventListener( 'クリック'、関数(){
 2      アニメーション(ウィンドウ、0 );
 3 })

図5に示すように、アニメーション関数アニメーションに(OBJ、ターゲット、コールバック) 

  ここでは、ウィンドウでオブジェクトobj; 0であるターゲット宛先、コールバックは、コールバック関数で、上院を通過しなかった場合、あなたは無視することができますが

  タイマーがのsetInterval()を設定されています。

  ステップ値としてステップを宣言、10(ステップにより分割スクロールバー差の現在の位置へ戻る位置の値が小さく、小さなを取得する、スクロール速度を遅くする高速からスクロールバーの速度を達成するために遅いなっていますアップスリップ)

VaRのステップ=(ターゲット- window.pageYOffset)/ 10。

  ステップが整数でない場合でも、ステップは、任意の更なるDiudiuを行くためにスクロールバーを作ることができ、常に整数ではありません。あなたはスライドアップすることができ、ステップがゼロより小さくてもよいので、スクロールバーの下、ゼロよりも大きくすることができます。切り上げゼロより大きく、切り捨てはゼロ未満であります

ステップ=ステップ> 0?Math.ceil(ステップ):Math.floor(ステップ)。

  window.scroll(x、y)の特定の場所を文書化するためにスクロールし、タイマー機能は、各スリップ1時を呼び出します

window.scroll(0、window.pageYOffset +ステップ)。

  決定したアニメーションが終了したか否か、タイマーてclearInterval(オフならば、それは)終了します。

1  IF(ターゲット== window.pageYOffset){   // 場合後部の上部にページバック(即ち、アニメーションの実行終了)クリアタイマ
2      てclearInterval(obj.timer);
 3      //   コールバック関数を渡すかどうかを判定する
。4      / * IF(コールバック){ 
 5。         コールバック();
 6      } * / 
7      //は、この以下に短縮することができます。オペレータが短絡されている&&、コールバックコールバック(すなわち、真の最初の式のために)()が存在し続けるであろう
。8      コールバック&& ;コールバック()
 9。 }

 

次のように詳細なコードは次のとおりです。

  1 <!DOCTYPE html>
  2 <html lang="en">
  3 <head>
  4     <meta charset="UTF-8">
  5     <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6     <meta http-equiv="X-UA-Compatible" content="ie=edge">
  7     <title>返回顶部效果</title>
  8     <style>
  9         .slider-bar {
 10             position: absolute;
 11             left: 47%;
 12             top: 300px;
 13             margin-left: 600px;
 14             width: 45px;
 15             height: 130px;
 16             background-color: pink;
 17             cursor: pointer;
 18         }
 19         .w {
 20             width: 1100px;
 21             margin: 10px auto;
 22         }
 23         .header {
 24             height: 150px;
 25             background-color: purple;
 26         }
 27         .banner {
 28             height: 250px;
 29             background-color: skyblue;
 30         }
 31         .main {
 32             height: 1000px;
 33             background-color: yellowgreen;
 34         }
 35         span {
 36             display: none;
 37             position: absolute;
 38             bottom: 0;
 39         }
 40     </style>
 41 </head>
 42 <body>
 43     <div class="slider-bar">
 44         <span class="goBack">返回顶部</span>
 45     </div>
 46     <div class="header w">头部区域</div>
 47     <div class="banner w">banner区域</div>
 48     <div class="main w">主体部分</div>
 49 
 50     <script>
 51         // querySelector() 方法返回匹配指定选择器()的第一个元素,传的必须是字符串
 52         var sliderbar = document.querySelector('.slider-bar');
 53         var banner = document.querySelector('.banner');
 54         var bannerTop = banner.offsetTop; // banner模块距离顶部的长度
 55         var sliderbarTop = sliderbar.offsetTop - bannerTop; // 侧边栏固定后距离顶部的长度
 56 
 57         var main = document.querySelector('.main');
 58         var goBack = document.querySelector('.goBack');
 59         var mainTop = main.offsetTop;  // main模块距离顶部的长度
 60         
 61         // scroll 屏幕发生滚动事件时执行
 62         document.addEventListener('scroll', function() {
 63             if(window.pageYOffset >= bannerTop) {    // window.pageYOffset 屏幕被滚上去的距离
 64                 sliderbar.style.position = 'fixed';   // 当用户滚到banner模块时使侧边栏变为固定状态
 65                 sliderbar.style.top = sliderbarTop + 'px'; 
 66             } else {
 67                 sliderbar.style.position = 'absolute';
 68                 sliderbar.style.top = '300px';
 69             }
 70             
 71             if(window.pageYOffset >= mainTop) {    // 当用户滚到main模块时显示返回顶部按钮
 72                 goBack.style.display = 'block';
 73             } else {
 74                 goBack.style.display = 'none';
 75             }
 76             
 77         });
 78         sliderbar.addEventListener('click', function() {
 79             animate(window, 0);
 80         })
 81 
 82         /* 动画函数:
 83          *  obj 做动画的对象(这里就是指window)
 84          *  target 目标位置(顶部)
 85          *  callback 回调函数(没有传参的话就不执行)
 86          */
 87         function animate(obj, target, callback) {
 88             clearInterval(obj.timer);  // 先清除定时器,保证只有一个定时器在执行,以免出现bug
 89             obj.timer = setInterval(function() {
 90                 // window.pageYOffset距离顶部的距离(是负的)
 91                 var step = (target - window.pageYOffset) / 10;  // step步长(让页面速度逐渐变慢的滑动上去)
 92                 step = step > 0 ? Math.ceil(step) : Math.floor(step); // step并不总是整数。大于零向上取整,小于零向下取整
 93                 if(window.pageYOffset == target) {  // 当页面回到顶部后(即动画执行完) 清除定时器
 94                     clearInterval(obj.timer);
 95                     //  判断是否传了回调函数
 96                     /* if(callback) { 
 97                         callback();
 98                     } */
 99                     // 可以简写为下边这种。 &&是短路运算符,存在callback(即第一个式子为true)时才会继续执行callback()
100                     callback && callback();
101                 }
102                 // window.scroll(x, y) 滚动到文档特定位置
103                 window.scroll(0, window.pageYOffset + step);
104             }, 15);
105         }
106     </script>
107 </body>
108 </html>

 

 

おすすめ

転載: www.cnblogs.com/sunyan-blog/p/11938954.html