网页轮播图(详细版)

article/2025/9/23 12:22:09

        在网页中,我们经常会看到各种轮播图的效果,它们到底是怎样实现的呢?今天,我们就一起来看一下!首先,我们需要准备若干张图片,在这里我准备了五张图片。
功能需求:

  • 鼠标经过轮播图模块,左右按钮显示,离开隐藏左右按钮。
  • 点击右侧按钮一次,图片往左播放一张,以此类推, 左侧按钮同理。
  • 图片播放的同时,下面小圆圈模块跟随一起变化。
  • 点击小圆圈,可以播放相应图片。
  • 鼠标不经过轮播图, 轮播图也会自动播放图片。
  • 鼠标经过,轮播图模块, 自动播放停止。

我们页面布局如下所示:
在这里插入图片描述
接下来就一步步的实现功能

先创建HTML页面。

        实现流程是:先给定一个大盒子,为了方便后面盒子的定位操作,再给它一个相对定位,把图片通过无序列表的形式添加进大盒子中,因为我们要实现的轮播图效果是横向的,所以我们可以给图片添加float:left属性,又因为图片所在的ul不够大,所以其他的图片会被挤到下面,所以我们可以手动修改图片所在的ul的大小;接下来写一个无序列表用于放置小圆圈,通过绝对定位的方式将其定位到大盒子的下面,在将小圆圈加进去,方便我们实现点击对应的小圆圈,就跳转到相应图片的效果。然后将左右箭头通过绝对定位分别定到大盒子两侧合适位置。最后,我们再将大盒子外面的内容隐藏掉。

<!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><link rel="stylesheet" href="index.css">
</head>
<body><div class="box"><a href="" class = 'left jiantou'>&lt;</a><a href="" class = 'right jiantou'>&gt;</a><ul class = 'pic'><li><a href="#"><img src="./images/1.jpg" alt=""></a></li><li><a href="#"><img src="./images/2.jpg" alt=""></a></li><li><a href="#"><img src="./images/3.jpg" alt=""></a></li><li><a href="#"><img src="./images/4.jpg" alt=""></a></li><li><a href="#"><img src="./images/5.jpg" alt=""></a></li></ul><ul class="lis"><li></li><li class = 'selected'></li><li></li><li></li><li></li></ul></div>
</body>
</html>

css文件

*{margin: 0;padding: 0;
}
li{list-style: none;
}
.box{position: relative;overflow: hidden;margin: 100px auto;width: 520px;height: 280px;background-color: red;
}
.jiantou{font-size: 24px;text-decoration: none;display: block;text-align: center;width: 20px;height: 30px;line-height: 30px;background: rgba(158, 154, 154, 0.7);color: white;z-index: 999;
}
.left{position: absolute;top: 125px;left: 0px;border-top-right-radius: 15px;border-bottom-right-radius: 15px;
}
.right{position: absolute;top:125px;left: 500px;border-top-left-radius: 15px;border-bottom-left-radius: 15px;
}
img{width: 520px;height: 280px;
}
.box .pic{width: 600%;
}
.pic li {float: left;
}
.lis{position: absolute;bottom: 15px;left: 50%;margin-left: -35px;width: 70px;height:13px;border-radius: 7px; background: rgba(158, 154, 154, 0.7);
}
.lis li {float: left;width: 8px;height: 8px;margin: 3px;border-radius: 50%;background-color: #fff;}
.lis .selected{background-color: cyan;
}

此时页面效果为:
在这里插入图片描述

再实现js部分的功能。

1、当鼠标经过轮播图模块,左右按钮显示,离开隐藏左右按钮。

        首先,我们先通过display:none让我们初始的两个箭头隐藏;然后获取两个箭头和大盒子,在给大盒子添加鼠标经过和鼠标离开事件。如下所示:

 var left = document.querySelector('.left');var right = document.querySelector('.right');var box = document.querySelector('.box');box.addEventListener('mouseenter',function(){left.style.display = 'block';right.style.display = 'block';})box.addEventListener('mouseleave',function(){left.style.display = 'none';right.style.display = 'none';})

实现效果为:
在这里插入图片描述

2、动态生成小圆圈

        先删除掉所有的小圆圈的li,如图所示:
在这里插入图片描述
        因为我们创建的小圆圈是根据图片的张数决定的,所以我们的核心思路就是:小圆圈的个数要跟图片张数一致,先得到ul里面图片的张数(图片放入li里面,所以就是li的个数),然后利用循环动态通过创建节点createElement(‘li’)和插入节点 ul. appendChild(li)生成小圆圈(这个小圆圈要放入ul里面)要注意第一个小圆圈需要添加selected类。
实现代码为:

var pic = document.querySelector('.pic');var lis = document.querySelector('.lis');for(var i = 0;i<pic.children.length;i++){var li = document.createElement('li');lis.appendChild(li);}lis.children[0].className = 'selected';

实现效果为:
在这里插入图片描述

3、点击小圆圈,小圆圈变色

        在生成小li的同时,根据排他思想,给小圆圈添加点击事件,当点击对应的小圆圈时,让其添加selected类,其余的小圆圈删除selected类。
代码为:

li.addEventListener('click',function(){for(var i =0;i<lis.children.length;i++){lis.childern[i].className = '';}this.className = 'selected';})

实现效果为:
在这里插入图片描述

4、点击小圆圈滚动图片

        这里就用到动画函数,前面已经讲过怎样封装动画函数,这里不在赘述,直接引用。但是要注意将动画函数的js文件放在我们index.js的上面。又因为只有添加了定位了元素才可以使用动画函数,我们还需要给pic这个ul添加定位。然后根据规律发现: 点击某个小圆圈 ,ul滚动的距离为: 小圆圈的索引号乘以图片的宽度。(因为图片是向左走,所以为负值)所以需要知道小圆圈的索引号, 我们就可以在生成小圆圈的时候,给它设置一个自定义属性,点击的时候获取这个自定义属性。
先在生成li的时候设置索引:

li.setAttribute('index',i);

        然后在给li添加点击事件的时候获得索引,并得到图片宽度,调用动画函数:

li.addEventListener('click',function(){var boxWidth = box.offsetWidth;//获得索引号var index = this.getAttribute('index');for(var i = 0;i<lis.children.length;i++){lis.children[i].className = '';}this.className = 'selected';animate(pic,-index*boxWidth)
})

实现效果为:
在这里插入图片描述

5、点击右侧按钮一次,就让图片滚动一张。

        可以直接给右侧按钮添加点击事件,声明一个变量num, 点击一次,自增1, 让这个变量乘以图片宽度,就是 ul 的滚动距离。

var num = 0;right.addEventListener('click',function(){num++;animate(pic,-num*boxWidth);})

实现效果为:
在这里插入图片描述
        我们发现,当点击右侧按钮时,可以实现图片的切换效果,但是当点击到最后一张图片的时候,就会停留在显页面初始背景,并不美观,所以我们就可以通过图片无缝滚动原理让图片无缝滚动,操作方法为。将.pic列表里的第一个li通过cloneNode(true)添加一份,然后通过appendChild()复制到该列表的末尾,然后再在js页面中给num添加一个判断条件,即当num的值等于这个列表里面元素的个数-1的时候,让ul移动的距离变为0,并让num等于0。
代码为:

var first = pic.children[0].cloneNode(true);pic.appendChild(first);//右侧按钮的功能var num = 0;right.addEventListener('click',function(){if(num == pic.children.length-1){pic.style.left = 0;num = 0;}num++;animate(pic,-num*boxWidth);})

实现效果为:
在这里插入图片描述
成功实现。

6、点击右侧按钮, 小圆圈跟随变化

        需要进行的操作是:再声明一个变量circle,每次点击右侧按钮时自增1,因为当我们左侧按钮点击时也会实现该效果,也需要这个变量,因此要声明全局变量。但是图片有5张,我们小圆圈只有4个少一个,必须加一个判断条件,如果circle == 4就 从新复原为 0。

 var num = 0;
var circle = 0;right.addEventListener('click',function(){if(num == pic.children.length-1){pic.style.left = 0;num = 0;}num++;animate(pic,-num*boxWidth);circle++;if(circle == lis.children.length){circle = 0;}for(var i =0;i<lis.children.length;i++){lis.children[i].className = '';}lis.children[circle].className = 'selected';})

运行结果为:
在这里插入图片描述
        但是这样还是有点小问题的,当我们让小圆圈和右侧按钮结合起来使用的时候,就会发现错误,如下:
在这里插入图片描述
        当我们点击小圆点时,也可以跳转到相应的图片页,但当我们继续点击右侧按钮时,就会发现下面的小圆点和对应的图片不对应了。这是我们我们的右侧按钮点击事件时通过变量num来控制的,而num变量和小圆圈的点击事件没有任何关系,所以就存在差异。
我们的解决方案就是每次点击小li时,获得它的索引号,然后把numcircle的值改为得到的索引号的值,代码为:

var index = this.getAttribute('index');
num = index;
circle = index;

实现效果为:

在这里插入图片描述

7、左侧按钮功能制作

和右侧按钮做法类似,不在赘述,代码如下:

left.addEventListener('click',function(){if(num == 0){num = pic.children.length-1;pic.style.left = -num*boxWidth+'px';}num--;animate(pic,-num*boxWidth);circle--;if(circle <0){circle = lis.children.length-1;}for(var i =0;i<lis.children.length;i++){lis.children[i].className = '';}lis.children[circle].className = 'selected';})

实现效果为:
在这里插入图片描述

8、自动播放功能

        其实添加一个定时器自动播放轮播图,就类似于点击了右侧按钮,此时我们使用手动调用右侧按钮点击事件 right.click(),鼠标经过图片就停止定时器 ,鼠标离开图片就开启定时器。

var timer = this.setInterval(function(){right.click();},2000)

实现效果为:
在这里插入图片描述
完整index.js的代码为:

window.addEventListener('load',function(){var left = document.querySelector('.left');var right = document.querySelector('.right');var box = document.querySelector('.box');box.addEventListener('mouseenter',function(){left.style.display = 'block';right.style.display = 'block';})box.addEventListener('mouseleave',function(){left.style.display = 'none';right.style.display = 'none';})var pic = document.querySelector('.pic');var lis = document.querySelector('.lis');var boxWidth = box.offsetWidth;for(var i = 0;i<pic.children.length;i++){var li = document.createElement('li');lis.appendChild(li);//设置索引号li.setAttribute('index',i);li.addEventListener('click',function(){//获得索引号var index = this.getAttribute('index');num = index;circle = index;for(var i = 0;i<lis.children.length;i++){lis.children[i].className = '';}this.className = 'selected';animate(pic,-index*boxWidth)})}lis.children[0].className = 'selected';//克隆第一个livar first = pic.children[0].cloneNode(true);pic.appendChild(first);var num = 0;var circle = 0;//右侧按钮的功能right.addEventListener('click',function(){if(num == pic.children.length-1){pic.style.left = 0;num = 0;}num++;animate(pic,-num*boxWidth);circle++;if(circle == lis.children.length){circle = 0;}for(var i =0;i<lis.children.length;i++){lis.children[i].className = '';}lis.children[circle].className = 'selected';})//左侧按钮功能left.addEventListener('click',function(){if(num == 0){num = pic.children.length-1;pic.style.left = -num*boxWidth+'px';}num--;animate(pic,-num*boxWidth);circle--;if(circle <0){circle = lis.children.length-1;}for(var i =0;i<lis.children.length;i++){lis.children[i].className = '';}lis.children[circle].className = 'selected';})var timer = this.setInterval(function(){right.click();},2000)
})

至此,我们轮播图的全部功能都实现了,你学会了吗?


http://chatgpt.dhexx.cn/article/BWQ5Zx8n.shtml

相关文章

轮播图 (无缝轮播图)

1.无缝轮播核心: 在最后多加一张第一张图, 当达到最后一张t1的时候 一瞬间将ul拉回到0的位置 结构&#xff1a; <div class"wrap"><ul><li><img src"./image/t1.png" alt""></li><li><img src"./i…

JS来实现轮播图(走马灯)可左右切换图片,鼠标移入会停止轮播

效果一&#xff1a; 会自动进行轮播&#xff0c;当鼠标进入轮播图区域会停止轮播&#xff0c;点击左右箭头可以向前、向后进行切换图片 效果二&#xff1a; 这种效果比第一种效果简单&#xff0c;只要删除一些代码和修改一些样式即可。 实现原理 轮播图整体是放在ul里的&…

oracle nvl函数 mysql_关于Oracle数据库中的nvl函数

以前将数据库查询结果展示在页面时&#xff0c;对于值null的字段&#xff0c;总是要判断下&#xff0c;如果为null&#xff0c;就显示ldquo;rdquo;&#xff0c;突然发现这个方法好笨 以前将数据库查询结果展示在页面时&#xff0c;对于值null的字段&#xff0c;总是要判断下&am…

nvl 函数初识

根据bi业务逻辑写sql时&#xff0c;在写法上有些区别&#xff0c;我习惯用case when &#xff0c;没有用过nvl所以试一试 bi某一列的业务如下&#xff1a; 我用sql分别试了case when 和 nvl &#xff0c;得到的结果是一致的 &#xff0c; 使用nvl函数的部分sql&#xff1a; …

MySQL中创 NVL 函数

NVL的定义 NVL(s1, s2)&#xff1a;当s1为null时&#xff0c;返回s2&#xff0c;否则返回s1。 SELECT NVL(S, R) FROM DUAL; -- S SELECT NVL(NULL, R) FROM DUAL; -- RNVL方法的兼容策略 第一种&#xff1a;用 case when 代替 NVL&#xff0c;这种方法代码改造量较大&am…

Xp 激活

2019独角兽企业重金招聘Python工程师标准>>> 为了在xp下测试一键安装 支持多语言、多用户、多数据库、完美URL之路过秋天版博客发布[绝对有杀伤力的博客] 这两天为xp激活折腾了不少时间,在不断用ghost还原来还原去的,原因就是我有一张OEM版本的系统,正常方式的…

Windows XP Professional With SP3 VOL[MSDN原版]+正版密钥

Windows XP Professional简体中文版,这是一个中国人最熟悉不过的操作系统了(也有人称它一个最适合中国人的操作系统)。Windows XP 由于其出色的安全性、可靠性、易用性、高性能,使它获得了巨大的成功,直至今天它仍然是全球使用率最高的操作系统。 下面我们来说说…

Windows.XP.x64.Pro.VOL(WINXP64位企业版)+正版序列号

Windows.XP.x64.Pro.VOL(WINXP64位企业版)的设计初衷是&#xff1a;满足机械设计和分析、三维动画、视频编辑和创作以及科学计算和高性能计算应用程序等领域中需要大量内存和浮点性能的客户的需求。 专用技术应用程序的性能优势 64 位计算性能在汽车或飞机设计等领域体现出优势…

如何查看XP系统的密匙

最近有网友提问IT视窗小编说他家现在用的是xp系统&#xff0c;如何查看XP系统的密匙呢。其实查看XP系统密匙还是比较的简单的&#xff0c;小编就把查看XP系统密匙的两种方法都写成教程分享给大家。下面就是小编作为大神教你如何查看XP系统的密匙。希望大家都喜欢我的教程。 1、…

IDEA 使用 README.md 介绍项目

IDEA 使用 README.md 介绍项目 文章目录 一.前言二.IDEA创建Markdown文件1.新建文件- 1.1.创建README.md文件 2.编辑md文件常用语法2.1.定义标题字号2.2. 文字样式2.2.1.文字斜体2.2.2.文字加粗2.2.3.文字删除线2.2.4. 引用文本 2.3.列表样式2.3.1 无符号列表2.3.2. 有符号列表…

Github美化README

GITHUB中的MD文件 在github中新建一个仓库Create a new repository时会有一个README文件&#xff0c;其实为自述文件&#xff0c;介绍这个仓库的基本概要。这个文件也是MD文件&#xff0c;可用软件typora和vscode等md软件进行拟写就行了。也是下面介绍的第三种方法。 编写方式…

README.md文件的作用及其文件内容的语法

README.md文件一般出现在项目的根目录下&#xff0c;其作用是对项目的主要信息进行描述。 如果一个项目你很长时间都没有动&#xff0c;突然你需要修改这个项目&#xff0c;那么通过README.md中对项目的描述能让你快速的再次上手&#xff1b; 或者别人拿到你的项目也能通过READ…

原来Github上的README.md文件这么有意思——Markdown语言详解

转载请注明出处&#xff1a;http://blog.csdn.net/zhaokaiqiang1992 之前一直在使用github&#xff0c;也在上面分享了不少的项目和Demo&#xff0c;每次创建新项目的时候&#xff0c;使用的都是默认的README.md文件&#xff0c;也不曾对这个文件有过什么了解。但是在看到别人写…

如何规范写出 README 模板?

README 标准是由 RichardLitt 发起&#xff0c;十多名开发者共同贡献完成的&#xff0c;在 GitHub 上有 1230 Star&#xff1a;standard-readme 标准 README 实例&#xff1a; standard-readme/tree/main/example-readmes奖励&#xff1a;实例 本文模板获取地址&#xff1a;…

GitHub README-Template.md - README.md 模板

GitHub README-Template.md - README.md 模板 A template to make good README.md. https://gist.github.com/PurpleBooth/109311bb0361f32d87a2 # Project TitleOne Paragraph of project description goes here## Getting StartedThese instructions will get you a copy o…

怎么写一个超棒的 README 文档

点击上方 Java后端&#xff0c;选择 设为星标 优质文章&#xff0c;及时送达 大数据文摘出品 来源&#xff1a;medium 编译&#xff1a;青柠 如果你很着急、只是想要模板&#xff0c;可以直接跳到底部&#xff08;但这样一点不酷&#xff09;&#xff0c;准备酷的人&#xff0c…

【工具推荐】最简单方法创建 README

CSDN话题挑战赛第1期 活动详情地址&#xff1a;https://marketing.csdn.net/p/bb5081d88a77db8d6ef45bb7b6ef3d7f 参赛话题&#xff1a;程序员常用小工具推荐 话题描述&#xff1a;俗话说&#xff0c;工欲善其事&#xff0c;必先利其器。作为每天和各种开发工具打交道的程序…

编写规范的readme文件

为什么要写这篇博客&#xff1f; 其实我是一个入坑已经半年的程序员&#xff0c;因为不是计算机专业&#xff0c;只能自己摸索&#xff0c;所以我深知博客的重要性。每次我的学习笔记啊&#xff0c;项目的&#xff0c;面试题啊&#xff0c;有的&#xff0c;只要有时间&#xff…

如何写好github上的README

项目名称&#xff08;超大字体或者是图片形式&#xff09; 这里再写一句骚气又精准的话描述你的项目吧 上手指南 写几句这样的话概括接下来的内容&#xff1a;以下指南将帮助你在本地机器上安装和运行该项目&#xff0c;进行开发和测试。关于如何将该项目部署到在线环境&…

README.md编写

一、摘要 项目一般会有个描述文件&#xff0c;对于项目的代码来讲&#xff0c;这个描述就是README.md文件&#xff0c;可以描述各模块功能、目录结构等。该文件可以方便让人快速了解项目的代码结构和功能。当然&#xff0c;若要深层次的了解项目&#xff0c;就得看项目总体的需…