gogogo
管理员
管理员
  • UID25
  • 粉丝0
  • 关注0
  • 发帖数1384
阅读:3979回复:0

原生js实现文字无缝滚动,速度可自行定义,鼠标放入悬停 good

楼主#
更多 发布于:2020-05-18 16:52
先了解 位置属性:


style.top:设置或返回定位元素的顶部位置
style.left:设置或返回定位元素的左边位置
offsetWidth:自己的的宽度,无单位。
style.width只能得到行内样式设置的宽度
offsetHeight:自己的的高度
offsetTop:距离上一个盒子的顶部的距离
offsetLeft:距离上一个盒子的左边距离
scrollTop:滚动条顶部滚动的像素
scrollLeft:滚动条左边滚动的像素




代码:




<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>文字无缝滚动</title>
<style>
*{
margin: 0;
padding: 0
}
#wrapper{
overflow:hidden;
height:100px;
width:500px;
background:#ccc;
color:#006600;
margin: 100px auto;
text-align: center;
}
</style>
</head>
<body>
   <div id="wrapper">  
<div id="demo1">  
<p>恭喜 手机号为11111****5610 的用户喜获 100元 现金券</p>  
<p>恭喜 手机号为22222****5611 的用户喜获 100元 现金券</p>  
<p>恭喜 手机号为33333****5612 的用户喜获 100元 现金券</p>  
<p>恭喜 手机号为44444****5613 的用户喜获 100元 现金券</p>
</div>  
<div id="demo2">
</div>  
</div>
</body>
</html>


<script>  
var speed = 80;  // 可自行设置文字滚动的速度

var wrapper = document.getElementById('wrapper');
var demo1 = document.getElementById('demo1');
var demo2 = document.getElementById('demo2');
 
demo2.innerHTML=demo1.innerHTML   //克隆demo1为demo2  
function Marquee(){  
if(demo2.offsetHeight-wrapper.scrollTop<=0)  //当滚动至demo1与demo2交界时  
wrapper.scrollTop-=demo1.offsetHeight    //demo跳到最顶端  
else{  
wrapper.scrollTop++   //如果是横向的 将 所有的 height top 改成 width left  
}  
}  

var MyMar=setInterval(Marquee,speed)  //设置定时器  
wrapper.onmouseover=function() {clearInterval(MyMar)}   //鼠标移上时清除定时器达到滚动停止的目的  
wrapper.onmouseout=function() {MyMar=setInterval(Marquee,speed)}  //鼠标移开时重设定时器  
</script>
游客


返回顶部