javascript

3.轮播图

3.1轮播图-交互

  • 问题1 最后一张切换到第一张的时候 会倒着移动

    • 分析原因:最后一张图到第一张图 是left值-2400px 到 0px的过程 就有倒叙效果

    • 解决方法:在最后再添加第一张图片 给用户造成视觉差

  • 问题2:最后一张图片的指示点对应不上

    • 分析原因: n = 4 oSpan[4]不存在

    • 解决方法:n=4是第一张图片 让oSpan[0]设置背景色

<script>
        // 1.自动切换   定时器
        var list = document.getElementsByClassName("list")[0];
        var oSpan = document.getElementsByTagName("span");
        var oBox = document.getElementsByClassName("box")[0];
        var timer = setInterval(auto, 1000);
        var n = 0;
        function auto() {
            // 显示第一张  left -800px*0
            // 显示第二张  left -800px*1
            // 显示第三张  left -800px*2
            // 显示第四张  left -800px*3
            // 显示第一张   left  -800px*4
            n++;
            if (n > 4) {
                list.style.left = "0px";
                n = 1;
            }
            move(list, "left", 100, -800 * n);
            /*
                问题1 最后一张切换到第一张的时候  会倒着移动
                解决方法:在最后再添加第一张图片 给用户造成视觉差
            */
            // 改变指示点颜色
            for (var i = 0; i < oSpan.length; i++) {
                oSpan[i].style.backgroundColor = "#fff";
            }
            /*
                问题2:最后一张图片的指示点对应不上
                分析原因:n = 4   oSpan[4]不存在  
                解决方法:n=4是第一张图片   让第一个指示显示
            */
            if (n == 4) {
                oSpan[0].style.backgroundColor = "red"
            } else {// n= 1 2 3 让对应span显示红色背景
                // 第一张图   oSpan[0]   第二章图 oSpan[1]
                oSpan[n].style.backgroundColor = "red";
            }
        }
        // 2.划入盒子  停止图片切换
        oBox.onmouseover = function () {
            clearInterval(timer);
        }
        // 3.滑出盒子   开启图片切换
        oBox.onmouseout = function () {
            timer = setInterval(auto, 1000)
        }
        // 4.点击左箭头   切换图片
        // 5.点击右箭头   切换图片
        // 6.点击指示点   切换图片
    </script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值