0


网页轮播图(详细版)

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

功能需求:

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

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

先创建HTML页面。

  1. 实现流程是:先给定一个大盒子,为了方便后面盒子的定位操作,再给它一个相对定位,把图片通过无序列表的形式添加进大盒子中,因为我们要实现的轮播图效果是横向的,所以我们可以给图片添加
  1. floatleft

属性,又因为图片所在的

  1. ul

不够大,所以其他的图片会被挤到下面,所以我们可以手动修改图片所在的

  1. ul

的大小;接下来写一个无序列表用于放置小圆圈,通过绝对定位的方式将其定位到大盒子的下面,在将小圆圈加进去,方便我们实现点击对应的小圆圈,就跳转到相应图片的效果。然后将左右箭头通过绝对定位分别定到大盒子两侧合适位置。最后,我们再将大盒子外面的内容隐藏掉。

  1. <!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文件

  1. *{
  2. margin:0;
  3. padding:0;}
  4. li{
  5. list-style: none;}.box{
  6. position: relative;
  7. overflow: hidden;
  8. margin:100px auto;
  9. width:520px;
  10. height:280px;
  11. background-color: red;}.jiantou{
  12. font-size:24px;
  13. text-decoration: none;
  14. display: block;
  15. text-align: center;
  16. width:20px;
  17. height:30px;
  18. line-height:30px;
  19. background:rgba(158,154,154,0.7);
  20. color: white;
  21. z-index:999;}.left{
  22. position: absolute;
  23. top:125px;
  24. left:0px;
  25. border-top-right-radius:15px;
  26. border-bottom-right-radius:15px;}.right{
  27. position: absolute;
  28. top:125px;
  29. left:500px;
  30. border-top-left-radius:15px;
  31. border-bottom-left-radius:15px;}
  32. img{
  33. width:520px;
  34. height:280px;}.box .pic{
  35. width:600%;}.pic li {
  36. float: left;}.lis{
  37. position: absolute;
  38. bottom:15px;
  39. left:50%;
  40. margin-left:-35px;
  41. width:70px;
  42. height:13px;
  43. border-radius:7px;
  44. background:rgba(158,154,154,0.7);}.lis li {
  45. float: left;
  46. width:8px;
  47. height:8px;
  48. margin:3px;
  49. border-radius:50%;
  50. background-color: #fff;}.lis .selected{
  51. background-color: cyan;}

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

再实现js部分的功能。

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

  1. 首先,我们先通过
  1. display:none

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

  1. var left = document.querySelector('.left');var right = document.querySelector('.right');var box = document.querySelector('.box');
  2. box.addEventListener('mouseenter',function(){
  3. left.style.display ='block';
  4. right.style.display ='block';})
  5. box.addEventListener('mouseleave',function(){
  6. left.style.display ='none';
  7. right.style.display ='none';})

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

2、动态生成小圆圈

  1. 先删除掉所有的小圆圈的li,如图所示:

在这里插入图片描述
因为我们创建的小圆圈是根据图片的张数决定的,所以我们的核心思路就是:小圆圈的个数要跟图片张数一致,先得到

  1. ul

里面图片的张数(图片放入

  1. li

里面,所以就是

  1. li

的个数),然后利用循环动态通过创建节点

  1. createElement(‘li’)

和插入节点

  1. ul. appendChild(li)

生成小圆圈(这个小圆圈要放入

  1. ul

里面)要注意第一个小圆圈需要添加

  1. selected

类。
实现代码为:

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

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

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

  1. 在生成小
  1. li

的同时,根据排他思想,给小圆圈添加点击事件,当点击对应的小圆圈时,让其添加

  1. selected

类,其余的小圆圈删除

  1. selected

类。
代码为:

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

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

4、点击小圆圈滚动图片

  1. 这里就用到动画函数,前面已经讲过怎样封装动画函数,这里不在赘述,直接引用。但是要注意将动画函数的js文件放在我们index.js的上面。又因为只有添加了定位了元素才可以使用动画函数,我们还需要给
  1. pic

这个

  1. ul

添加定位。然后根据规律发现: 点击某个小圆圈 ,

  1. ul

滚动的距离为: 小圆圈的索引号乘以图片的宽度。(因为图片是向左走,所以为负值)所以需要知道小圆圈的索引号, 我们就可以在生成小圆圈的时候,给它设置一个自定义属性,点击的时候获取这个自定义属性。
先在生成li的时候设置索引:

  1. li.setAttribute('index',i);
  1. 然后在给li添加点击事件的时候获得索引,并得到图片宽度,调用动画函数:
  1. li.addEventListener('click',function(){var boxWidth = box.offsetWidth;//获得索引号var index =this.getAttribute('index');for(var i =0;i<lis.children.length;i++){
  2. lis.children[i].className ='';}this.className ='selected';animate(pic,-index*boxWidth)})

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

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

  1. 可以直接给右侧按钮添加点击事件,声明一个变量
  1. num

, 点击一次,自增1, 让这个变量乘以图片宽度,就是

  1. ul

的滚动距离。

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

实现效果为:
在这里插入图片描述
我们发现,当点击右侧按钮时,可以实现图片的切换效果,但是当点击到最后一张图片的时候,就会停留在显页面初始背景,并不美观,所以我们就可以通过图片无缝滚动原理让图片无缝滚动,操作方法为。将

  1. .pic

列表里的第一个

  1. li

通过

  1. cloneNode(true)

添加一份,然后通过

  1. appendChild()

复制到该列表的末尾,然后再在js页面中给

  1. num

添加一个判断条件,即当

  1. num

的值等于这个列表里面元素的个数-1的时候,让

  1. ul

移动的距离变为0,并让

  1. num

等于0。
代码为:

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

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

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

  1. 需要进行的操作是:再声明一个变量
  1. circle

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

  1. circle == 4

就 从新复原为 0。

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

运行结果为:
在这里插入图片描述
但是这样还是有点小问题的,当我们让小圆圈和右侧按钮结合起来使用的时候,就会发现错误,如下:
在这里插入图片描述
当我们点击小圆点时,也可以跳转到相应的图片页,但当我们继续点击右侧按钮时,就会发现下面的小圆点和对应的图片不对应了。这是我们我们的右侧按钮点击事件时通过变量

  1. num

来控制的,而

  1. num

变量和小圆圈的点击事件没有任何关系,所以就存在差异。
我们的解决方案就是每次点击小

  1. li

时,获得它的索引号,然后把

  1. num

  1. circle

的值改为得到的索引号的值,代码为:

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

实现效果为:

在这里插入图片描述

7、左侧按钮功能制作

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

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

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

8、自动播放功能

  1. 其实添加一个定时器自动播放轮播图,就类似于点击了右侧按钮,此时我们使用手动调用右侧按钮点击事件
  1. right.click()

,鼠标经过图片就停止定时器 ,鼠标离开图片就开启定时器。

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

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

  1. window.addEventListener('load',function(){var left = document.querySelector('.left');var right = document.querySelector('.right');var box = document.querySelector('.box');
  2. box.addEventListener('mouseenter',function(){
  3. left.style.display ='block';
  4. right.style.display ='block';})
  5. box.addEventListener('mouseleave',function(){
  6. left.style.display ='none';
  7. 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');
  8. lis.appendChild(li);//设置索引号
  9. li.setAttribute('index',i);
  10. li.addEventListener('click',function(){//获得索引号var index =this.getAttribute('index');
  11. num = index;
  12. circle = index;for(var i =0;i<lis.children.length;i++){
  13. lis.children[i].className ='';}this.className ='selected';animate(pic,-index*boxWidth)})}
  14. lis.children[0].className ='selected';//克隆第一个livar first = pic.children[0].cloneNode(true);
  15. pic.appendChild(first);var num =0;var circle =0;//右侧按钮的功能
  16. right.addEventListener('click',function(){if(num == pic.children.length-1){
  17. pic.style.left =0;
  18. num =0;}
  19. num++;animate(pic,-num*boxWidth);
  20. circle++;if(circle == lis.children.length){
  21. circle =0;}for(var i =0;i<lis.children.length;i++){
  22. lis.children[i].className ='';}
  23. lis.children[circle].className ='selected';})//左侧按钮功能
  24. left.addEventListener('click',function(){if(num ==0){
  25. num = pic.children.length-1;
  26. pic.style.left =-num*boxWidth+'px';}
  27. num--;animate(pic,-num*boxWidth);
  28. circle--;if(circle <0){
  29. circle = lis.children.length-1;}for(var i =0;i<lis.children.length;i++){
  30. lis.children[i].className ='';}
  31. lis.children[circle].className ='selected';})var timer =this.setInterval(function(){
  32. right.click();},2000)})

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

标签: css html css3

本文转载自: https://blog.csdn.net/m0_48375854/article/details/122125100
版权归原作者 bear*6 所有, 如有侵权,请联系我们删除。

“网页轮播图(详细版)”的评论:

还没有评论