拖動滾動條實現div跟隨效果程式碼例項

admin發表於2017-10-18

線上客服系統大家都比較熟悉,一般會在網頁的側欄顯示,並且,當拖動滾動條的時候,客服系統能夠跟隨滾動,並且一般會帶有緩衝效果,下面就通過程式碼例項,詳細介紹一下如何實現此特效。

程式碼如下:

[HTML] 純文字檢視 複製程式碼
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css">
#div1 {
  width:50px;
  height:200px;
  background:#0000FF;
  position:absolute;
  right:0;
  bottom:50px;
}
</style>
<script type="text/javascript">
window.onscroll=function() 
{
  var oDiv=document.getElementById('div1');
  var DivScroll=document.documentElement.scrollTop || document.body.scrollTop; 
  move(parseInt((document.documentElement.clientHeight-oDiv.offsetHeight)/2+DivScroll));    
};
var timer=null;
function move(end) {
  clearInterval(timer);
  timer=setInterval(function(){       
    var oDiv=document.getElementById('div1');
    var speed=(end-oDiv.offsetTop)/5;  
    speed=speed>0?Math.ceil(speed):Math.floor(speed);       
    if(oDiv.offsetTop == end) {        
      clearInterval(timer);
    }
    else {
      oDiv.style.top=oDiv.offsetTop+speed+'px';
    }
  }, 30);
}
</script>
</head>
<body style="height:1000px;">
<div id="div1"> </div>
</body>
</html>

以上程式碼實現了我們的要求,當拖動滾動條的時候,div塊能夠跟隨滾動。

相關文章