用js实现轮播图效果

今天来说一下利用js实现轮播图效果,供大家参考,具体内容如下

思路

1.首先我们要把需要用到的元素获取过来

<div class="all" id='box'>
        <div class="screen">
            <!-- 无序列表 -->
            <ul>
                <li><img src="./wf1.jpg" width="500" height="200" /></li>
                <li><img src="./wf2.jpg" width="500" height="200" /></li>
                <li><img src="./wf3.jpg" width="500" height="200" /></li>
                <li><img src="./wf4.jpg" width="500" height="200" /></li>
                <li><img src="./wf5.jpg" width="500" height="200" /></li>
            </ul>
            <!-- 有序列表 -->
            <ol>

            </ol>
        </div>
        <div id="arr"><span id="left">&lt;</span><span id="right">&gt;</span></div>
</div>

2.我们要让轮播图点到哪里执行到哪里,且颜色发生变化

3.给轮播图添加左右方向键,可以上下切换

4.让轮播图自己动起来

操作

1.先获取到元素,和需要用到的轮播图效果

1.先把需要用到的ul(照片),ol(点击框),nth(左右的按键)获取过来

var ul=document.querySelector('ul')
var ol=document.querySelector('ol')
var nth=document.querySelector('#arr')
var box=document.querySelector('#box')
var left=document.querySelector('#left')
var  right=document.querySelector('#right')

2.封装一下动画效果,一会要用到

 // 进行位置动画封装调用
        function animate(element,offset,setp,times){
                    // 判断为true则删除,防止多个触发
                    if(element.jsq){
                        clearInterval(element.jsq)
                    }
                    // 获取当前offset
                    var position=ul.offsetLeft
                    // 判定如果移动位置小于现在的位置,则步长为负数
                    if(offset<position){
                        setp=-setp
                    }
                    // 开启间隙定时器
                    if(Math.abs(position-offset)>Math.abs(setp)){
                        element.jsq=setInterval(() => {
                        position+=setp
                        element.style.left=position+'px'
                        // 判断要是现在的位值和预订的位置相差不超过一步长,则停止计时器
                        if(Math.abs(position-offset)<Math.abs(setp)){
                            clearInterval(element.jsq)
                            element.style.left=offset+'px'
                        }
                    }, times);
                    }
                }

动画的步骤:

1.传入时,查看是否有计时器的存在,如果有则清空,防止多个计时器并存的效果

2.判断一下,要移动到的位置是否大于原来的位置,大于则setp则加,小于则每次减去步长

3.开始计时器,进行移动

4.当现在的位置,和预定位置,距离相差小于步长则结束计时器,并把位置定到预定的位置上去,防止反复横跳

2.ol添加内容,加点击事件,图片移动,按钮变色

for(var i=0;i<ul.children.length;i++){
        var li=document.createElement('li')
            li.innerHTML=i+1
            // 给每一个li设置上自定义属性
            li.setAttribute('a',i)
            ol.appendChild(li)
            // 给ol下面每一个li设置点击事件
            ol.children[i].onclick=function(){
                // 循环所以li进行排他思想
                for(var i=0;i<ol.children.length;i++){
                    ol.children[i].className=''
                }
                // 给当前点击的元素添加上class属性
                this.className='current'
                // 获取到当前点击li的自定属性的值看看是点击到第几张
                var index=this.getAttribute('a')
                console.log(index)
                // 查看照片每一张的宽度
                var imgwidth=ul.children[0].offsetWidth
                // 根据宽度乘上第几张得出该移动多少
                offset=index*-imgwidth
                // 调用动画函数
                animate(ul,offset,50,30)

1.根据照片的数量去用for循环创建相同数量的按钮,用setAttriubre(‘a',i)创建新自定义属性后添加到ol中,后边要用到

for(var i=0;i<ul.children.length;i++){
        var li=document.createElement('li')
            li.innerHTML=i+1
            // 给每一个li设置上自定义属性
            li.setAttribute('a',i)
            ol.appendChild(li)
}

2.在这个循环中给所有的按钮添加绑定事件,让当前的按钮变颜色,其他的没有颜色,排他思想,在每一次点击的时候,当前的有,其他的全部清空

for(var i=0;i<ul.children.length;i++){
        var li=document.createElement('li')
            li.innerHTML=i+1
            // 给每一个li设置上自定义属性
            li.setAttribute('a',i)
            ol.appendChild(li)

        //新
            // 给ol下面每一个li设置点击事件
            ol.children[i].onclick=function(){
                // 循环所以li进行排他思想
                for(var i=0;i<ol.children.length;i++){
                    ol.children[i].className=''
                }
                // 给当前点击的元素添加上class属性
                this.className='current'

3.获取到当前点击的元素,的自定义属性的值,保存起来,用来设置页面的偏移量当前点击的值和每个照片相乘得出 ul的偏移量,记得加负号,应为是ul往左走,而不是视口往左走,然后调用之前我们写的动画函数

for(var i=0;i<ul.children.length;i++){
        var li=document.createElement('li')
            li.innerHTML=i+1
            // 给每一个li设置上自定义属性
            li.setAttribute('a',i)
            ol.appendChild(li)
            // 给ol下面每一个li设置点击事件
            ol.children[i].onclick=function(){
                // 循环所以li进行排他思想
                for(var i=0;i<ol.children.length;i++){
                    ol.children[i].className=''
                }
                // 给当前点击的元素添加上class属性
                this.className='current'

        //新
                // 获取到当前点击li的自定属性的值看看是点击到第几张
                var index=this.getAttribute('a')
                console.log(index)
                // 查看照片每一张的宽度
                var imgwidth=ul.children[0].offsetWidth
                // 根据宽度乘上第几张得出该移动多少
                offset=index*-imgwidth
                // 调用动画函数
                animate(ul,offset,50,30)

得出效果

3.给轮播图添加上一张,下一张按钮

(这里就不写css的样式了,最后会给到,先脑补。css最开始的时候是隐藏的)

1.开始获取过各种元素,所以现在就不需要获取,进入和离开分别写上事件就好了

// 鼠标进入事件
    box.onmousemove=function(){
        nth.style.display='block'
    }
    // 鼠标离开事件
    box.onmouseleave=function(){
        nth.style.display='none'
    }

2.获取到当前页面,  设置点击事件,下一个++  上一个--,然后套用之前onclick效果

for(var i=0;i<ul.children.length;i++){
        var li=document.createElement('li')
            li.innerHTML=i+1
            // 给每一个li设置上自定义属性
            li.setAttribute('a',i)
            ol.appendChild(li)
            // 给ol下面每一个li设置点击事件
            ol.children[i].onclick=function(){
                // 循环所以li进行排他思想
                for(var i=0;i<ol.children.length;i++){
                    ol.children[i].className=''
                }
                // 给当前点击的元素添加上class属性
                this.className='current'
                // 获取到当前点击li的自定属性的值看看是点击到第几张
                var index=this.getAttribute('a')
                console.log(index)
                // 查看照片每一张的宽度
                var imgwidth=ul.children[0].offsetWidth
                // 根据宽度乘上第几张得出该移动多少
                offset=index*-imgwidth
                // 调用动画函数
                animate(ul,offset,50,30)

                 //  新
                // 点击事件,index为当前点击的序号的自定义类名的值
                left.onclick=function(){
                if(index>0){
                    index--
                }
                ol.children[index].click()
                }
                right.onclick=function(){

                    if(index<4){
                        index++
                    }
                ol.children[index].click()
                }

            }
}

因为点击事件里面的值在外面获取不到,索性我就接着写

事件里面还可以调用事件  如 ol.children[index].click()   记得要加小括号,并且去掉on

3.在没有触发ol.onclick(没有点击下边的1,2,3,4,5)的时候,点击左右是不起效果的,所以在script上要添加一段代码

var Click=0

    right.onclick=function(){
        Click++
        if(Click==1){
          ol.children[1].click()
        }
    }

这个时候就完成了第三部分的操作

4.让轮播图自己动起来

// 自动移动
    // 1.首先我们要在一开始的时候给第一个按钮添加颜色
    ol.children[0].className='current'
    // 2.开启计时器每5秒切换一次
    setInterval(function(){
        var position=ul.offsetLeft
        var imgwidth=ul.children[0].offsetWidth
        var indexs=Math.abs(position/imgwidth)
        //3. 获取现在的位置,和图片的长度,相除得到下标
        if(indexs>3){
            indexs=-1
        }
        ol.children[indexs+1].click()
        // 跳转的时候一定要加1
        },5000)

1.首先我们要在一开始的时候给第一个按钮添加颜色,往后排他思想删除掉

2.得出下标,跳转要加1,要不然原地跳,第二圈开始的时候为-1,不是0,应为要+1操作

就可以的到我们想要的结果了

整体代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style type="text/css">
        * {
            padding: 0;
            margin: 0;
            list-style: none;
            border: 0;
        }

        .all {
            width: 500px;
            height: 200px;
            padding: 7px;
            border: 1px solid #ccc;
            margin: 100px auto;
            position: relative;
        }

        .screen {
            width: 500px;
            height: 200px;
            overflow: hidden;
            position: relative;
        }

        .screen li {
            width: 500px;
            height: 200px;
            overflow: hidden;
            float: left;
        }

        .screen ul {
            position: absolute;
            left: 0;
            top: 0px;
            width: 3000px;
        }

        .all ol {
            position: absolute;
            right: 10px;
            bottom: 10px;
            line-height: 20px;
            text-align: center;
        }

        .all ol li {
            float: left;
            width: 20px;
            height: 20px;
            background: #fff;
            border: 1px solid #ccc;
            margin-left: 10px;
            cursor: pointer;
        }

        .all ol li.current {
            background: yellow;
        }

        #arr {
            display: none;
            z-index: 1000;

        }

        #arr span {
            width: 40px;
            height: 40px;
            position: absolute;
            left: 5px;
            top: 50%;
            margin-top: -20px;
            background: #000;
            cursor: pointer;
            line-height: 40px;
            text-align: center;
            font-weight: bold;
            font-family: '黑体';
            font-size: 30px;
            color: #fff;
            opacity: 0.3;
            border: 1px solid #fff;
        }

        #arr #right {
            right: 5px;
            left: auto;
        }
    </style>
</head>
<body>
    <div class="all" id='box'>
        <div class="screen">
            <!-- 无序列表 -->
            <ul>
                <li><img src="./wf1.jpg" width="500" height="200" /></li>
                <li><img src="./wf2.jpg" width="500" height="200" /></li>
                <li><img src="./wf3.jpg" width="500" height="200" /></li>
                <li><img src="./wf4.jpg" width="500" height="200" /></li>
                <li><img src="./wf5.jpg" width="500" height="200" /></li>
            </ul>
            <!-- 有序列表 -->
            <ol>

            </ol>
        </div>
        <div id="arr"><span id="left">&lt;</span><span id="right">&gt;</span></div>
    </div>
    <script>
        // 进行位置动画封装调用
        function animate(element,offset,setp,times){
                    // 判断为true则删除,防止多个触发
                    if(element.jsq){
                        clearInterval(element.jsq)
                    }
                    // 获取当前offset
                    var position=ul.offsetLeft
                    // 判定如果移动位置小于现在的位置,则步长为负数
                    if(offset<position){
                        setp=-setp
                    }
                    // 开启间隙定时器
                    if(Math.abs(position-offset)>Math.abs(setp)){
                        element.jsq=setInterval(() => {
                        position+=setp
                        element.style.left=position+'px'
                        // 判断要是现在的位值和预订的位置相差不超过一步长,则停止计时器
                        if(Math.abs(position-offset)<Math.abs(setp)){
                            clearInterval(element.jsq)
                            element.style.left=offset+'px'
                        }
                    }, times);
                    }
                }
    //  1.获取元素
    var ul=document.querySelector('ul')
    var ol=document.querySelector('ol')
    var nth=document.querySelector('#arr')
    var box=document.querySelector('#box')
    var left=document.querySelector('#left')
    var  right=document.querySelector('#right')
    // 2.ol中添加点击元素
    // 在ol循环添加li
    for(var i=0;i<ul.children.length;i++){
        var li=document.createElement('li')
            li.innerHTML=i+1
            // 给每一个li设置上自定义属性
            li.setAttribute('a',i)
            ol.appendChild(li)
            // 给ol下面每一个li设置点击事件
            ol.children[i].onclick=function(){
                // 循环所以li进行排他思想
                for(var i=0;i<ol.children.length;i++){
                    ol.children[i].className=''
                }
                // 给当前点击的元素添加上class属性
                this.className='current'
                // 获取到当前点击li的自定属性的值看看是点击到第几张
                var index=this.getAttribute('a')
                console.log(index)
                // 查看照片每一张的宽度
                var imgwidth=ul.children[0].offsetWidth
                // 根据宽度乘上第几张得出该移动多少
                offset=index*-imgwidth
                // 调用动画函数
                animate(ul,offset,50,30)
                // 点击事件,index为当前点击的序号的自定义类名的值
                left.onclick=function(){
                if(index>0){
                    index--
                }
                ol.children[index].click()
                }
                right.onclick=function(){

                    if(index<4){
                        index++
                    }
                ol.children[index].click()
                }
            }
    }
 // 鼠标进入事件
    box.onmousemove=function(){
        nth.style.display='block'
    }
    // 鼠标离开事件
    box.onmouseleave=function(){
        nth.style.display='none'
    }
     //鼠标右边点击事件
     var Click=0

    right.onclick=function(){

        Click++

        if(Click==1){

          ol.children[1].click()

        }

    }

// 自动移动
    // 1.首先我们要在一开始的时候给第一个按钮添加颜色
    ol.children[0].className='current'
    // 2.开启计时器每5秒切换一次
    setInterval(function(){
        var position=ul.offsetLeft
        var imgwidth=ul.children[0].offsetWidth
        var indexs=Math.abs(position/imgwidth)
        //3. 获取现在的位置,和图片的长度,相除得到下标
        if(indexs>3){
            indexs=-1
        }
        ol.children[indexs+1].click()
        // 跳转的时候一定要加1
        },5000)
    </script>
</body>
</html>

记得更改图片的路径。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • js实现轮播图的完整代码

    今天写一个完整的轮播图,首先它需要实现三个功能: 1.鼠标放在小圆点上实现轮播 2.点击焦点按钮实现轮播 3.无缝自动轮播 轮播图的原理: 一系列的大小相等的图片平铺,利用CSS布局只显示一张图片,其余隐藏.通过计算偏移量(封装一个动画函数)自动播放,或通过手动点击事件切换图片. html布局: <div id="box" class="all"> <div class="inner"> <!-- 相框-->

  • JS实现左右无缝轮播图代码

    废话不多说了,直接给大家贴代码了. 无缝轮播图: <title>无缝轮播图</title> <style> *{margin: 0;padding:0; } ul{list-style: none;} .banner{width: 600px;height: 300px;border: 2px solid #ccc;margin: 100px auto;position: relative;overflow: hidden;} .img{position: absolu

  • 原生js实现无限循环轮播图效果

    知识要点 1.实现无限循环的原理: 以偏移的距离来判断是否跳回第一张和最后一张 也可以利用循环判断图片的当前索引值 var newLeft=parseInt(list.style.left)+offset;//当前的偏移量+下一次的偏移量=新的偏移量 list.style.left=newLeft+"px";//当前的偏移值=新的偏移值 //以偏移的距离来判断是否跳回第一张和最后一张 if(newLeft>-600){ list.style.left=-3000+"px

  • 原生js实现轮播图的示例代码

    很多网站上都有轮播图,但却很难找到一个系统讲解的,因此这里做一个简单的介绍,希望大家都能有所收获,如果有哪些不正确的地方,希望大家可以指出. 原理: 将一些图片在一行中平铺,然后计算偏移量再利用定时器实现定时轮播. 步骤一:建立html基本布局 如下所示: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>轮播图</title> </hea

  • js实现从左向右滑动式轮播图效果

    轮播图就是让图片每隔几秒自动滑动,达到图片轮流播放的效果.轮播图从效果来说有滑动式的也有渐入式的,滑动式的轮播图就是图片从左向右滑入的效果,渐入式的轮播图就是图片根据透明度渐渐显示的效果,这里说的是实现第一种效果的方法. 原理 相同大小的图片并成一列,但只显示其中一张图片,其余的隐藏,通过修改left值来改变显示的图片. 点击查看效果 html部分 nav为总容器,第一个ul列表#index为小圆点列表,鼠标覆盖哪个小圆点就显现第几张图片,on是一个给小圆点添加背景颜色属性的类:第二个ul列表#

  • JS实现自动轮播图效果(自适应屏幕宽度+手机触屏滑动)

    1.本文使用js+jQuery实现轮播图,需要引用jquery包,另种实现分别是animate实现自适应的轮播,以及transform平滑轮播(在注释代码中). 2.代码中的图片大家自己更换就可以了,样式和逻辑均写在js里. 3.html标签代码,js代码 <div class="slider"> //轮播箭头 <p class="lastpic"><img src="../images/prev.png">&

  • 使用html+js+css 实现页面轮播图效果(实例讲解)

    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=

  • js实现点击左右按钮轮播图片效果实例

    本文实例讲述了js实现点击左右按钮轮播图片效果的方法.分享给大家供大家参考.具体实现方法如下: $(function () { var index = 1; var pPage = 1; var $v_citemss = $(".citemss"); var $v_show = $v_citemss.find("ul"); v_width = $v_citemss.width();//图片展示区外围div的大小 //注:若为整数,前边不能再加var,否则会被提示un

  • JS轮播图实现简单代码

    本文实例为大家分享了js轮播图实现代码,供大家参考,具体内容如下 思路: 1.首先要有个盛放图片的容器,设置为单幅图片的宽高,且overflow:hidden,这样保证每次可以只显示一个图片 2.Container内有个放图片的list进行position的定位 ,其中的图片采用float的方式,同时当图片进行轮播时,改变list的Left值使得其显示的图片发生变化. 3.图片的轮播使用定时器,通过定时器改变list的Left值是的图片循环展示 4.当鼠标滑动到图片上时,清除定时器,图片停止轮播

  • js实现支持手机滑动切换的轮播图片效果实例

    本文实例讲述了js实现支持手机滑动切换的轮播图片效果的方法.分享给大家供大家参考.具体如下: 运行效果如下: 完整实例代码点击此处本站下载. 使用方法案例: <script type="text/javascript" src="../src/zepto.js"></script> <script type="text/javascript" src="../src/carousel-image.js&qu

随机推荐