原生JS实现走马灯效果

<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title></title>
<style>
* {margin:0; padding:0;}
#div1,#div2{ width:630px; height:260px; border:2px solid red; margin:100px auto; overflow:hidden}
ul{ position:relative; left:0; top:0; list-style:none}
li{ float:left;}
</style>
</head>


<body>
<div id="div1">
<ul>
    <li><img src="images/01.jpg" /></li>
    <li><img src="images/02.jpg" /></li>
    <li><img src="images/03.jpg" /></li>
    <li><img src="images/04.jpg" /></li>
    </ul>
</div>
<div id="div2">
<ul>
    <li><img src="images/01.jpg" /></li>
    <li><img src="images/02.jpg" /></li>
    <li><img src="images/03.jpg" /></li>
    <li><img src="images/04.jpg" /></li>
    </ul>
</div>


</body>
</html>
<script>
function marquee(box_id,speed){//传id  speed 速度

var oDiv=document.getElementById(box_id);

//ul填充图片
var oUl=oDiv.getElementsByTagName('ul')[0];
var aLi=oDiv.getElementsByTagName('li');

var timer;
var i=0;//定时器用的 计时器

var w=400*aLi.length;  //一套图片的宽度,注意本例中每个图片的宽度为400px

oUl.innerHTML+=oUl.innerHTML;//复制一套图片

oUl.style.width=w*2+"px";
//-------------------------------------------------

//重复代码封装函数
function run(){
timer=setInterval(function(){
i-=speed;//计时器步进
oUl.style.left=i+"px";

if(i<=-w){//如果移动过一套图片的宽度,归零
i=0;
};
},30);
};

//首次调用
run();

//----------------------------------------------

//鼠标进入停止
oDiv.οnmοuseοver=function(){
clearInterval(timer);
};

//鼠标移出继续
oDiv.οnmοuseοut=function(){
run();
};

};


//------------------------------------------------------
marquee("div1",20);
marquee("div2",10);













</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值