网页轮播图代码分享(html+css+原生js)

网页轮播图是我们网页常常需要使用的效果,现在也有各种框架或是插件可以很好地实现网页轮播图,但了解其布局及js实现原理也是很有必要的,尤其是对于刚接触js的人,学会轮播图的实现原理,对js的理解及深入学习也是大有裨益的,于是跟着视频教学,编写了网页轮播图,代码分享如下:

一、html布局代码

<body>
    <div class="mylunbo">
        <a href="javascript:;" class="arrow-l"><</a>
        <a href="javascript:;" class="arrow-r">></a>
        <ul>
            <li>
                <a href="#"><img src="2.png" width="720" height="432" alt="" /></a>
            </li>
            <li>
                <a href="#"><img src="1.png" width="720" height="432" alt="" /></a>
            </li>
            <li>
                <a href="#"><img src="3.jpeg" width="720" height="432" alt="" /></a>
            </li>
            <li>
                <a href="#"><img src="4.jpeg" width="720" height="432" alt="" /></a>
            </li>
        </ul>
        <ol class="circle">

        </ol>
    </div>
</body>

二、css层叠样式表

*{
    padding:0;
    margin:0;
}
.mylunbo{
    margin:20px auto;
    position: relative;
    width: 720px;
    height: 432px;
    /*background-color: purple;*/
    overflow: hidden;
}
img{
    width:720px;
    height:432px;
}
.mylunbo ul{
    position: absolute;
    top: 0;
    left: 0;
    width:500%;
}
ul li{
    float:left;
    list-style-type: none;
}
ol li{
    list-style-type: none;
}
.arrow-l,
.arrow-r {
    display: none;
    position: absolute;
    top: 50%;
    margin-top: -20px;/*高度40,上移20*/
    width: 24px;
    height: 40px;
    background: rgba(0, 0, 0, .3);
    text-align: center;
    line-height: 40px;
    color: #fff;
    font-family: 'icomoon';
    font-size: 18px;
    z-index: 2;
}
.arrow-r {
    right: 0;
}
.circle {
    position: absolute;
    bottom: 10px;
    left: 350px;
}
.circle li {
    float: left;
    width: 8px;
    height: 8px;
    /*background-color: #fff;*/
    border: 2px solid rgba(240, 120, 120, 0.5);
    margin: 0 3px;
    border-radius: 50%;
    /*鼠标经过显示小手*/
    cursor: pointer;
}
.current {
    background-color: #fff;
}
a:hover{
    color:red;
}

三、js代码(animate.js+index.js)

function animate(obj,length,callback){
    clearInterval(obj.timer);
    obj.timer=setInterval(function(){
        var step=(length-obj.offsetLeft)/10; // 缓动效果,步长=(目标值-当前值)/10
        step=step>0 ? Math.ceil(step) : Math.floor(step);
        if(obj.offsetLeft==length){
            clearInterval(obj.timer);
            if(callback)
                callback();
            //callback && callback()
        }
            obj.style.left=obj.offsetLeft+step+'px';
        },15);
}
window.addEventListener('load',function(){
    const lunbo=document.querySelector(".mylunbo");
    const arrowl=document.querySelector(".arrow-l");
    const arrowr=document.querySelector(".arrow-r");
    var num=0;  // 左右移动按钮定位图片
    var circle=0;  // 定位小圆点
    var flag=true;  // 节流阀
    //1、右侧按钮,左侧按钮
    lunbo.addEventListener('mouseenter',function(){
        arrowl.style.display='block';
        arrowr.style.display='block';
        clearInterval(timer);  // 清楚计时器,轮播图不自动播放
        //timer=null;  // 清楚timer变量
    });
    lunbo.addEventListener('mouseleave',function(){
        arrowl.style.display='none';
        arrowr.style.display='none';
        timer=setInterval(function(){
            arrowr.click();
        },2000);
    });
    //2、创建小圆点
    const ul=lunbo.querySelector("ul");
    const ol=lunbo.querySelector("ol");
    for(let i=0;i<ul.children.length;i++){  // 根据图片数量生成小圆点
        let li=document.createElement("li");
        li.setAttribute('index',i);  // 添加自定义属性index
        ol.appendChild(li);
        //3、添加小圆圈点击事件
        li.onclick=function(){
            for(let i=0;i<ol.children.length;i++){
                ol.children[i].className='';
            }
            this.className='current';
            //4、小圆圈动画
            let lunbowidth=lunbo.offsetWidth;
            let index=this.getAttribute('index');
            num=circle=index;  // 点击小圆点时,将num和circle的值赋值为index,即将小圆点顺序和左右按钮的num定位到当前图片
            animate(ul,-index*lunbowidth);  // 调用动画函数,-index*lunboWidth为终点位置
        }
    }
    //5、克隆子元素-->ABCDA,此时最后一张图为第一张图的复制!!
    let child=ul.children[0].cloneNode(true);
    ul.appendChild(child);
    ol.children[0].className='current';
    //6、右侧按钮点击事件
    arrowr.addEventListener('click',function(){
        if(flag){
            flag=false;  // 未完成轮播动画,不能轮播,设置为false
            if(num==ul.children.length-1){
                ul.style.left=0;  // 当点击到最后一个图片时,即和第一幅图相同的那张,num为ul.children.length-1,先切换到第一张(很快),执行动画切换到第二张
                num=0;  // num重新设为0,后面再加1
            }
            num++;
            animate(ul,-num*lunbo.offsetWidth,function(){
                flag=true;  // 将flag设置为true,可以再次点击轮播
            });
            circle++;
            if(circle==ol.children.length)  // 当小圆圈移动到最后,点击右移,circle+1,此时circle为ol.children.length
                circle=0;
            setCurrent();
        }
    })
    //7、左侧点击事件
    arrowl.addEventListener('click',function(){
        if(flag){
            flag=false;
            if(num==0){
                num=ul.children.length-1;  // 当轮播图为第一张图时,num设为最后一张图的index,之后再减一
                ul.style.left=-num*lunbo.offsetWidth+'px';  // 先切换到最后一张图,之后再调用动画函数到实际倒数第二图
            }
            num--;
            animate(ul,-num*lunbo.offsetWidth,function(){
                flag=true;
            });
            circle--;
            if(circle==-1)  // 当小圆圈在第一个位置时,点击左移,circle-1,此时circle为-1
                circle=ol.children.length-1;
            setCurrent();
        }
    });
    var timer=setInterval(function(){
        arrowr.click();
    },2000);
    function setCurrent(){
        for(let i=0;i<ol.children.length;i++){
            ol.children[i].className='';
        }
        ol.children[circle].className='current';
    }
})

源码分享:

链接:https://pan.baidu.com/s/1DrXnGKlahm4XhdCmTjFvDg
提取码:2ldh

posted @ 2022-05-12 18:22  旺旺哈  阅读(23460)  评论(0编辑  收藏  举报