html实现轮播图--小圆圈呈中间大两边小的样式

这个轮播图的样式是参照奔驰官网的,原始效果图大概是这样

在这里插入图片描述


轮播图下面的小圆圈呈现出中间大,两边小的效果。先来看看最终的成品:

在这里插入图片描述


分析:假设按照奔驰官网的一样,轮播的图片有6张。明显可以看出,每个大圆的一侧最多有两个小圆,且小圆的半径依次在减小。

实现的功能有:
点击左右键能切换图片;点击小圆圈能切换图片,实现自动轮播;当鼠标放上去停止自动播放;大概鼠标离开后能自动播放。

完整代码(含详细注释):

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }

        li {
            list-style: none;
        }

        .big_box {
            position: relative;
            width: 500px;
            height: 400px;
            margin: 100px auto;
            overflow: hidden;
        }

        .big_box ul {
            position: absolute;
            left: 0;
            width: 700%;
            height: 400px;
        }

        .big_box ul li {
            float: left;
        }

        .big_box ul li img {
            width: 500px;
            height: 400px;
        }

        .left {
            position: absolute;
            top: 50%;
            left: 0;
            transform: translateY(-50%);
            background-color: rgba(0, 0, 0, 0.5);
            width: 30px;
            height: 30px;
            line-height: 30px;
            text-align: center;
            color: white;
        }

        .right {
            position: absolute;
            top: 50%;
            right: 0;
            transform: translateY(-50%);
            background-color: rgba(0, 0, 0, 0.5);
            width: 30px;
            height: 30px;
            line-height: 30px;
            text-align: center;
            color: white;
        }

        .big_box ol {
            position: absolute;
            bottom: 0;
            /* 这里别给ol限制宽度,让小圆圈的个数自动把ol撑大 */
            left: 50%;
            transform: translateX(-50%);
            height: 10%;
            line-height: 10%;
            text-align: center;
        }

        .big_box ol li {
            float: left;
            width: 20px;
            height: 20px;
            background-color: rgba(255, 255, 255, .5);
            border-radius: 50%;
            margin-left: 5px;
            display: none;
        }

        .big_box ol .current {
            background-color: rgb(211, 29, 29);
            display: block;
        }

        /* 第一层的样式 */
        .big_box ol .current1 {
            width: 15px;
            height: 15px;
            display: block;
            margin-top: 2.5px;
        }

        /* 第二层的样式 */
        .big_box ol .current2 {
            margin-top: 5px;
            width: 10px;
            height: 10px;
            display: block;
        }


        .left,
        .right,
        ol li {
            cursor: pointer;
        }
    </style>
</head>

<body>
    <div class="big_box">
        <!-- 轮播的图片 -->
        <ul>
            <li>
                <img src="imgs/picture1.png" alt="">
            </li>
            <li>
                <img src="imgs/picture7.png" alt="">
            </li>
            <li>
                <img src="imgs/picture3.png" alt="">
            </li>
            <li>
                <img src="imgs/picture4.png" alt="">
            </li>
            <li>
                <img src="imgs/picture5.png" alt="">
            </li>
            <li>
                <img src="imgs/picture6.png" alt="">
            </li>
        </ul>
        <!-- 左右按键 -->
        <div class="left">&lt</div>
        <div class="right">&gt</div>
        <!-- 小圆圈 -->
        <ol>

        </ol>
    </div>
    <script>
        var timer;
        var big_box = document.querySelector('.big_box');
        var ul = big_box.querySelector('ul');
        var ol = big_box.querySelector('ol');
        var lis_img = ul.querySelectorAll('li');
        var left = document.querySelector('.left');
        var right = document.querySelector('.right');
        var num = 0;  //记录要滑到第几张图片

        function animate(obj, target) {
            var timer1 = setInterval(function () {
                var current = obj.offsetLeft;
                var step = 10;
                step = current > target ? -step : step;
                // 下面要包括等于的情况,否则会发生抖动
                if (Math.abs(current - target) <= Math.abs(step)) {
                    clearInterval(timer1);
                    obj.style.left = target + 'px';
                }
                else {
                    obj.style.left = current + step + 'px';
                }
            }, 10)
        }

        //小圆圈样式改变-----最关键的步骤
        function circlechange(circles, circle) {
            //circle是当前所展示的图片的索引,也是要改变样式的圆圈的索引
            if (circle == lis_img.length) {
                circle = 0;
            }
            //排他思想设置小圆圈样式
            //排他思想第一步:先把所有的小圆圈样式去掉
            for (var i = 0; i < circles.length; i++) {
                circles[i].className = "";
            }
            //排他思想第二步:把当前图片对应的小圆圈设置样式
            circles[circle].className = "current";
            //大圆左边的两个圆
            if (circle - 1 >= 0) {
                circles[circle - 1].className = "current1";
            }
            if (circle - 2 >= 0) {
                circles[circle - 2].className = "current2";
            }
            //大圆右边的两个圆
            if (circle + 1 <= lis_img.length - 1) {
                circles[circle + 1].className = "current1";
            }
            if (circle + 2 <= lis_img.length - 1) {
                circles[circle + 2].className = "current2";
            }
        }

        //在页面刚加载进来就执行代码
        window.addEventListener('load', function () {
            //设置小圆点的个数
            for (var i = 0; i < lis_img.length; i++) {
                var li = document.createElement('li');
                ol.appendChild(li);
                // 给小圆圈添加自定义属性
                li.setAttribute('index', i);
                //一开始第一个小圆圈就是被选中状态
                if (i == 0) {
                    li.className = "current";
                }
                //给小圆圈添加点击处理事件
                li.addEventListener('click', function () {
                    //排他思想实现小圆圈样式改变
                    for (var j = 0; j < ol.children.length; j++) {
                        ol.children[j].className = "";
                    }
                    this.className = "current";
                    //实现点击小圆圈后图片滑动
                    var index = this.getAttribute('index');
                    animate(ul, -index * big_box.offsetWidth);
                    // 在图片滑动的同时对应的小圆圈样式也要发生改变,所以调用animate函数同时调用circlechange函数
                    circlechange(circles, index);
                })
            }
            //为了实现无缝衔接的切换图片,要把第一张图片克隆到最后一张图片的附近
            var circles = ol.querySelectorAll('li');
            // cloneNode函数若括号里面是true,则是深拷贝,false则是浅拷贝
            var li_img = ul.children[0].cloneNode(true);
            ul.appendChild(li_img);

            //点击右箭头向右滑动
            right.addEventListener('click', function () {
                //下面if代码是实现向右滑动的无缝衔接,不懂的建议自己手动模拟一遍
                if (num >= lis_img.length) {
                    num = 0;
                    //注意改变属性left的值后面一定要跟px,否则没有效果
                    ul.style.left = 0 + 'px';
                }
                num++;
                animate(ul, -num * big_box.offsetWidth);
                circlechange(circles, num);
            })
            //点击左箭头向左滑动
            left.addEventListener('click', function () {
                //下面if代码是实现向左滑动的无缝衔接,不懂的建议自己手动模拟一遍
                if (num <= 0) {
                    num = lis_img.length;
                    ul.style.left = -lis_img.length * big_box.offsetWidth + 'px';
                }
                num--;
                animate(ul, -num * big_box.offsetWidth);
                circlechange(circles, num);
            })

            //实现自动播放----因为自动播放的功能和向右滑动的功能一样,所以直接调用向右滑动的函数
            timer = setInterval(function () {
                right.click();
            }, 2000)

            //鼠标放到盒子上停止自动播放
            big_box.addEventListener('mouseover', function () {
                clearInterval(timer);
            })

            //鼠标离开自动播放
            big_box.addEventListener('mouseout', function () {
                clearInterval(timer);
                //在重新创建一个定时器时最好先清除一下定时器
                timer = setInterval(function () {
                    right.click();
                }, 2000)
            })
        })
    </script>
</body>

</html>

代码中所用到的图片素材如下:

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


学习编程是顺着互联网的发展潮流,是一件好事。新手如何学习编程?其实不难,不过在学习编程之前你得先了解你的目的是什么?这个很重要,因为目的决定你的发展方向、决定你的发展速度。
IT行业是什么工作做什么?IT行业的工作有:产品策划类、页面设计类、前端与移动、开发与测试、营销推广类、数据运营类、运营维护类、游戏相关类等,根据不同的分类下面有细分了不同的岗位。
女生学Java好就业吗?女生适合学Java编程吗?目前有不少女生学习Java开发,但要结合自身的情况,先了解自己适不适合去学习Java,不要盲目的选择不适合自己的Java培训班进行学习。只要肯下功夫钻研,多看、多想、多练
Can’t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock问题 1.进入mysql路径
oracle基本命令 一、登录操作 1.管理员登录 # 管理员登录 sqlplus / as sysdba 2.普通用户登录
一、背景 因为项目中需要通北京网络,所以需要连vpn,但是服务器有时候会断掉,所以写个shell脚本每五分钟去判断是否连接,于是就有下面的shell脚本。
BETWEEN 操作符选取介于两个值之间的数据范围内的值。这些值可以是数值、文本或者日期。
假如你已经使用过苹果开发者中心上架app,你肯定知道在苹果开发者中心的web界面,无法直接提交ipa文件,而是需要使用第三方工具,将ipa文件上传到构建版本,开...
下面的 SQL 语句指定了两个别名,一个是 name 列的别名,一个是 country 列的别名。**提示:**如果列名称包含空格,要求使用双引号或方括号:
在使用H5混合开发的app打包后,需要将ipa文件上传到appstore进行发布,就需要去苹果开发者中心进行发布。​
+----+--------------+---------------------------+-------+---------+
数组的声明并不是声明一个个单独的变量,比如 number0、number1、...、number99,而是声明一个数组变量,比如 numbers,然后使用 nu...
第一步:到appuploader官网下载辅助工具和iCloud驱动,使用前面创建的AppID登录。
如需删除表中的列,请使用下面的语法(请注意,某些数据库系统不允许这种在数据库表中删除列的方式):
前不久在制作win11pe,制作了一版,1.26GB,太大了,不满意,想再裁剪下,发现这次dism mount正常,commit或discard巨慢,以前都很快...
赛门铁克各个版本概览:https://knowledge.broadcom.com/external/article?legacyId=tech163829
实测Python 3.6.6用pip 21.3.1,再高就报错了,Python 3.10.7用pip 22.3.1是可以的
Broadcom Corporation (博通公司,股票代号AVGO)是全球领先的有线和无线通信半导体公司。其产品实现向家庭、 办公室和移动环境以及在这些环境...
发现个问题,server2016上安装了c4d这些版本,低版本的正常显示窗格,但红色圈出的高版本c4d打开后不显示窗格,
TAT:https://cloud.tencent.com/document/product/1340