我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript是怎样实现网页轮播图

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript是怎样实现网页轮播图

这篇文章将为大家详细讲解有关JavaScript是怎样实现网页轮播图,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

    前言:

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

    功能需求:

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

    • 点击右侧按钮一次,图片往左播放一张,以此类推, 左侧按钮同理。

    • 图片播放的同时,下面小圆圈模块跟随一起变化。

    • 点击小圆圈,可以播放相应图片。

    • 鼠标不经过轮播图, 轮播图也会自动播放图片。

    • 鼠标经过,轮播图模块, 自动播放停止。

    我们页面布局如下所示:

    JavaScript是怎样实现网页轮播图

    接下来就一步步的实现功能

    创建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" rel="external nofollow" ></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="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ><img class="lazy" data-src="./images/1.jpg" alt=""></a>            </li>            <li>                <a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ><img class="lazy" data-src="./images/2.jpg" alt=""></a>            </li>            <li>                <a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ><img class="lazy" data-src="./images/3.jpg" alt=""></a>            </li>            <li>                <a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ><img class="lazy" data-src="./images/4.jpg" alt=""></a>            </li>             <li>                <a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ><img class="lazy" data-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;}

    此时页面效果为:

    JavaScript是怎样实现网页轮播图

    实现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';    })

    实现效果为:

    JavaScript是怎样实现网页轮播图

    2、动态生成小圆圈

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

    JavaScript是怎样实现网页轮播图

            因为我们创建的小圆圈是根据图片的张数决定的,所以我们的核心思路就是:小圆圈的个数要跟图片张数一致,先得到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';

    实现效果为:

    JavaScript是怎样实现网页轮播图

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

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

    代码为:

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

    实现效果为:

    JavaScript是怎样实现网页轮播图

    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)})

    实现效果为:

    JavaScript是怎样实现网页轮播图

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

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

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

    实现效果为:

    JavaScript是怎样实现网页轮播图

            我们发现,当点击右侧按钮时,可以实现图片的切换效果,但是当点击到最后一张图片的时候,就会停留在显页面初始背景,并不美观,所以我们就可以通过图片无缝滚动原理让图片无缝滚动,操作方法为。将.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);    })

    实现效果为:

    JavaScript是怎样实现网页轮播图

    成功实现。

    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';  })

    运行结果为:

    JavaScript是怎样实现网页轮播图

            但是这样还是有点小问题的,当我们让小圆圈和右侧按钮结合起来使用的时候,就会发现错误,如下:

    JavaScript是怎样实现网页轮播图

            当我们点击小圆点时,也可以跳转到相应的图片页,但当我们继续点击右侧按钮时,就会发现下面的小圆点和对应的图片不对应了。这是我们我们的右侧按钮点击事件时通过变量num来控制的,而num变量和小圆圈的点击事件没有任何关系,所以就存在差异。
    我们的解决方案就是每次点击小li时,获得它的索引号,然后把numcircle的值改为得到的索引号的值,代码为:

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

    实现效果为:

    JavaScript是怎样实现网页轮播图

    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';    })

    实现效果为:

    JavaScript是怎样实现网页轮播图

    8、自动播放功能

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

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

    实现效果为:

    JavaScript是怎样实现网页轮播图

    完整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';    //克隆第一个li    var 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)})

    关于JavaScript是怎样实现网页轮播图就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    JavaScript是怎样实现网页轮播图

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    JavaScript是怎样实现网页轮播图

    这篇文章将为大家详细讲解有关JavaScript是怎样实现网页轮播图,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。前言: 在网页中,我们经常会看到各种轮播图的效果,它们到底是怎
    2023-06-22

    JavaScript怎么实现轮播图

    这篇文章主要介绍“JavaScript怎么实现轮播图”,在日常操作中,相信很多人在JavaScript怎么实现轮播图问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript怎么实现轮播图”的疑惑有所
    2023-06-25

    JavaScript然后实现六种网页图片轮播效果

    本篇文章给大家分享的是有关JavaScript然后实现六种网页图片轮播效果,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。在网页中,我们经常会看到各种轮播图的效果,它们到底是怎样
    2023-06-22

    Android 首页轮播图实现

    先看一下效果:(图片是有指示器的,只是被上层的视图挡住了,这里不需要这个东西)创建一个ViewHolder,解析布局和加载数据 package com.ydduong.gsa.adapter.holder import android.vi
    2022-06-06

    JavaScript如何实现首页图片轮播图效果

    这篇文章主要介绍“JavaScript如何实现首页图片轮播图效果”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript如何实现首页图片轮播图效果”文章能帮助大家解决问题。一、轮番图效果展
    2023-07-02

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录