您当前的位置:首页 > 网站建设 > javascript
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax |

用js实现轮播图效果

51自学网 2022-05-02 21:32:33
  javascript

今天来说一下利用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>

记得更改图片的路径。

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


javascript实现花样轮播效果
uniapp实现录音上传功能
51自学网,即我要自学网,自学EXCEL、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。
京ICP备13026421号-1