js无缝滚动

效果原理:让ul一直向左滚动
复制li,改变ul的宽度,
进行判断,是否越界
如果越界,重新定位。
控制向左向右,设定一个speed,更改其值的正负。

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>无缝轮播</title>
        <style>
            *{margin: 0;padding: 0;}
            #div1{width: 800px;height: 150px;margin: 100px auto;position: relative;background: blue;overflow: hidden;}
            #div1 ul{position: absolute;top: 0;left: 0;}
            #div1 ul li{list-style-type: none;float: left;width: 200px;height: 150px;;}
            img{width: 200px;height: 150px;}
        </style>
        <script>
            window.onload=function(){
                //控制向左向右,主要是通过是加还是减speed
                var speed=-2;
                function move(){
                        if(oUl.offsetLeft<-oUl.offsetWidth/2){
                            //当其往左移动了四个li的宽度时,把整个图片拉回来
                            oUl.style.left=0;
                        }
                        if(oUl.offsetLeft>0){
                            //记得末尾加px
                            oUl.style.left=-oUl.offsetWidth/2+'px';
                        }
                        oUl.style.left=oUl.offsetLeft+speed+'px';
                };
                var time=null;
                var oDiv = document.getElementById('div1');
                var oUl = oDiv.getElementsByTagName('ul')[0];
                var oLi = oDiv.getElementsByTagName('li');
                //使其形成8个li
                oUl.innerHTML = oUl.innerHTML+oUl.innerHTML;
                oUl.style.width = oLi[0].offsetWidth*oLi.length+'px';

                time = setInterval(move,30);
                oDiv.onmouseover= function(){
                    clearInterval(time);
                }
                oDiv.onmouseout= function(){
                    time = setInterval(move,30);
                }
                var oBtn = document.getElementsByTagName('button');
                oBtn[0].onclick = function(){
                    speed = -2;
                }
                oBtn[1].onclick = function(){
                    speed = 2;
                }
            }


        </script>
    </head>
    <body>
        <button value="向左走">向左走</button>
        <button value="向右走">向右走</button>
        <div id="div1">
            <ul>
                <li><img src="img/1.jpg"></li>
                <li><img src="img/3.jpg"></li>
                <li><img src="img/4.jpg"></li>
                <li><img src="img/2.jpg"></li>
            </ul>
        </div>

    </body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值