zoukankan      html  css  js  c++  java
  • 原装js轮播图,鼠标移入停止轮播,移出继续轮播

    要求:1、点击按钮,切换图片;
       2、图片能够自动轮播;
          3、鼠标移入,轮播停止;移出继续轮播;
    知识点:1、定时器:setInterval();
        2、鼠标移入事件:onmouseenter/onmouseover;
          鼠标移出事件:onmouseleave/onmouseout;
    难点:假设轮播图轮播到第二张图片,此时点击第一张图片,我们想要的效果是鼠标移出后,图片轮播到第二张图片,到事实是轮播到第三张图片。
     
    **********************************************************************************************************
     
    代码:
     
     
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>主页</title>
        <style>
            * {
                padding: 0;
                margin: 0;
            }
            li {
                list-style: none;
            }
            img {
                vertical-align: top;
            }
            .wrapBox {
                 1226px;
                height: 460px;
                margin: 50px auto;
                position: relative;
            }
            .wrapBox img {
                 100%;
            }
            .showBox li {
                display: none;
            }
            .showBox .show {
                display: block;
            }
            .dotBox {
                overflow: hidden;
                position: absolute;
                right: 50px;
                bottom: 20px;
            }
            .dotBox li {
                 20px;
                height: 20px;
                background-color: #fff;
                border-radius: 50%;
                float: left;
                margin: 0 10px;
            }
            .dotBox .active {
                background-color: #3399CC;
            }
        </style>
    </head>
    <body>
        <div class="wrapBox">
            <ul class="dotBox">
                <li class="active"></li>
                <li></li>
                <li></li>
                <li></li>
            </ul>
            <ul class="showBox">
                <li class="show"><img src="../img/1.jpg" alt=""></li>
                <li><img src="../img/2.jpg" alt=""></li>
                <li><img src="../img/3.jpg" alt=""></li>
                <li><img src="../img/4.jpg" alt=""></li>
            </ul>
        </div>
    </body>
    <script>
        var dotLi = document.querySelectorAll(".dotBox li");
        var showLi = document.querySelectorAll(".showBox li");
        var wrapBox = document.querySelector(".wrapBox");
        console.log(dotLi, showLi, wrapBox);



        // 1、点击按钮切换对应图片
        for (let i = 0; i < dotLi.length; i++) {
            var li = dotLi[i];
            li.onclick = function () {
       //解决难点问题(当点击时,把i即被点击的按钮下标,赋值给index即可)
                index = i;
                // 循环遍历所有的li按钮,并清空颜色类名
                for (let j = 0; j < dotLi.length; j++) {
                    dotLi[j].className = "";
                    showLi[j].className = "";
                }
                // 给点击的按钮,添加颜色类名
                dotLi[i].className = "active";
                showLi[i].className = "show";
            }
        }
        // 2、自动轮播,定时器
        // 图片下标位置,默认为0
        var index = 0;
        var timer = null;
        // 页面加载时,调用一次
        playTime();
        function playTime() {
            // var timer = setInterval(function () {
            // timer要改为全局变量
            timer = setInterval(function () {
                // 每过两秒,下标加一,跳到下一张
                index++;
                // 当图片走完最后一张,也就是下标为4的时候,跳到第一张
                if (index == 4) {
                    index = 0;
                }
                for (let j = 0; j < dotLi.length; j++) {
                    dotLi[j].className = "";
                    showLi[j].className = "";
                }
                // 给点击的按钮,添加颜色类名
                dotLi[index].className = "active";
                showLi[index].className = "show";
            }, 2000)
        }
        // 3、当鼠标移入wrapBox时,停止轮播,清除定时器
        wrapBox.onmouseenter = function () {
            clearInterval(timer);
        }
        // 4、当鼠标移出wrapBox时,继续轮播,重新调用定时器
        wrapBox.onmouseleave = function () {
            playTime();
        }
    </script>
    </html>
     
    效果图:
     
  • 相关阅读:
    idHTTP使用代理IP
    Delphi的TRegistry注册表类方法详解
    判断WebBrowser是否加载完成.
    vs2010 安装记
    Delphi中destroy, free, freeAndNil, release用法和区别
    IdHTTP处理HTTP 302遇到的问题
    passcal 多线程例子,线程管理,创建,暂停,中止,等待等。。。
    passcal try嵌套
    passcal 编写多线程程序
    用一个 Byte 数表示 8 个复选框的选择状态
  • 原文地址:https://www.cnblogs.com/zhang-qi/p/12182797.html
Copyright © 2011-2022 走看看