中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript實現跟隨滾動緩沖運動廣告框

發布時間:2020-09-28 09:41:36 來源:腳本之家 閱讀:237 作者:梵海pp 欄目:web開發

當我們瀏覽一些網頁時我們會發現頁面的的邊上會有廣告圖片,當滾動滾動條的時候這些廣告圖片會跟隨性的隨頁面一起運動(這里我叫它為廣告框)。一些網頁的廣告框是固定在瀏覽器上的用background:fixed;便可實現。這里我用JavaScript簡單的制作了一個隨滾動緩沖運動的廣告框。

JavaScript實現跟隨滾動緩沖運動廣告框

制作的原理比較簡單,大家都有一個完美的js運動框架,這里的緩沖運動需要用到。這里的廣告框設定的是跟隨滾動條緩沖運動并運動到瀏覽器的中間位置。需要理解的是運動距離的計算和一些細節上的處理(一些BUG的預防)

這是我在這里使用的一個js運動框架,傳遞的參數只有一個并不是完美運動框架。傳遞的參數是廣告框的運動距離,因此我在運動框架內又獲取了一次對象。

var timer=null;
    function startMover(iTarget){
      var oDiv=document.getElementById('div1');
      clearInterval(timer);
      timer=setInterval(function(){
          var ispeed=(iTarget-oDiv.offsetTop)/8;
          //速度設置為逐漸減小
          ispeed=ispeed>0?Math.ceil(ispeed):Math.floor(ispeed);
          //避免速度產生小數點
          if(oDiv.offsetTop==iTarget){
            clearInterval(timer);
          }
          else{
          oDiv.style.top=oDiv.offsetTop+ispeed+"px";
          }

    },30);
    };

樣式和布局代碼

  <style>
    #div1{
      width: 100px;
      height: 100px;
      background: #ccc;
      position: absolute;
      //使用絕對定位讓其處于右上方
      right: 0;
      top: 0;
  </style>

  <body >
    <div id="div1"></div>
  </body>


js代碼

這里增加了.onscroll屬性目的是當滾動滾動條的時候也加載頁面,廣告框就能隨著滾動條一起運動了。還增加了.onresize屬性,由于我要實現廣告框一直是運動到瀏覽器的中間位置,然而當我改變瀏覽器高度的時候也要實現廣告框的運動,所以增加該屬性,當瀏覽器大小改變時加載。

<script>
    window.onload=window.onscroll=window.onresize=function(){

      var oDiv=document.getElementById('div1');
      var scrolltop=document.documentElement.scrollTop||document.body.scrollTop;
"scrolltop"是滾動條滾動的距離,這里有一個兼容chrome不支持document.documentElement.scrollTop獲取語句,其他瀏覽器支持。          
      var t=(document.documentElement.clientHeight-oDiv.offsetHeight)/2;
"t"為讓廣告框處于中間位置的高度距離,(獲取瀏覽器的總高度-廣告框自身高度)/2      
      startMover(parseInt(t+scrolltop));
"parseIn"返回一個整數,避免小數生成。這里廣告框的總移動距離為(t+scrolltop)    
    };

    var timer=null;
    function startMover(iTarget){
      var oDiv=document.getElementById('div1');
      clearInterval(timer);
      timer=setInterval(function(){
          var ispeed=(iTarget-oDiv.offsetTop)/8;

          ispeed=ispeed>0?Math.ceil(ispeed):Math.floor(ispeed);

          if(oDiv.offsetTop==iTarget){
            clearInterval(timer);
          }
          else{
          oDiv.style.top=oDiv.offsetTop+ispeed+"px";
          }

    },30);
    };

  </script>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兴海县| 余干县| 郧西县| 沧州市| 湖北省| 周口市| 绥德县| 乌兰县| 武胜县| 资兴市| 灌南县| 房产| 剑川县| 永靖县| 玉屏| 抚宁县| 宿松县| 通辽市| 时尚| 鄄城县| 胶南市| 南乐县| 伊宁县| 张家港市| 芮城县| 定结县| 岳西县| 张掖市| 德化县| 富裕县| 郓城县| 瑞昌市| 柏乡县| 乌鲁木齐市| 缙云县| 贵定县| 石楼县| 福安市| 彰化县| 油尖旺区| 荃湾区|