左右⽆缝轮播html,JS实现左右⽆缝轮播图代码
废话不多说了,直接给⼤家贴代码了。
⽆缝轮播图:
⽆缝轮播图
*{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: absolute;top: 0;left: 0}
.img li{float: left;}
.num{position: absolute;bottom: 10px;width: 100%;text-align: center;font-size: 0;}
.
num li{width: 10px;height: 10px;background:rgba(0,0,0,0.5);display: block;border-radius: 100%;display: inline-block;margin: 0 5px;cursor: pointer;}
.btn{display: none;}
.btn span{display: block;width: 50px;height: 100px;background: rgba(0,0,0,0.6);color: #fff;font-size: 40px;line-height:
100px;text-align: center;cursor:pointer;}
.btn .prev{position: absolute;left: 0;top: 50%;margin-top: -50px;}
.btn .next{position: absolute;right: 0;top: 50%;margin-top: -50px;}
.num .active{background-color: #fff;}
<
$(function(){
>
var i=0;
var timer=null;
for (var j = 0; j < $('.img li').length; j++) { //创建圆点
$('.num').append('
')
}
$('.num li').first().addClass('active'); //给第⼀个圆点添加样式
var firstimg=$('.img li').first().clone(); //复制第⼀张图⽚
$('.img').append(firstimg).width($('.img li').length*($('.img img').width())); //将第⼀张图⽚放到最后⼀张图⽚后,设置ul的宽度为图⽚张数*图⽚宽度
// 下⼀个按钮
$('.next').click(function(){
i++;
if (i==$('.img li').length) {
i=1; //这⾥不是i=0
$('.img').css({left:0}); //保证⽆缝轮播,设置left值
};
$('.img').stop().animate({left:-i*600},300);
if (i==$('.img li').length-1) { //设置⼩圆点指⽰
$('.num li').eq(0).addClass('active').siblings().removeClass('active');
}else{
$('.num li').eq(i).addClass('active').siblings().removeClass('active');
}
})
// 上⼀个按钮
$('.prev').click(function(){
i--;
if (i==-1) {
i=$('.img li').length-2;
$('.img').css({left:-($('.img li').length-1)*600});
}
$('.img').stop().animate({left:-i*600},300);
$('.num li').eq(i).addClass('active').siblings().removeClass('active');
})
/
/设置按钮的显⽰和隐藏
$('.banner').hover(function(){
$('.btn').show();
},function(){
$('.btn').hide();
})
//⿏标划⼊圆点
$('.num li').mouseover(function(){
var _index=$(this).index();
$('.img').stop().animate({left:-_index*600},150);
$('.num li').eq(_index).addClass('active').siblings().removeClass('active');
})
//定时器⾃动播放
timer=setInterval(function(){
i++;
if (i==$('.img li').length) {
i=1;
$('.img').css({left:0});
};
$('.img').stop().animate({left:-i*600},300);
if (i==$('.img li').length-1) {
$('.num li').eq(0).addClass('active').siblings().removeClass('active'); }else{
$('.num li').eq(i).addClass('active').siblings().removeClass('active'); }
},1000)
//⿏标移⼊,暂停⾃动播放,移出,开始⾃动播放
$('.banner').hover(function(){
clearInterval(timer);
},function(){
timer=setInterval(function(){
i++;
if (i==$('.img li').length) {
i=1;
$('.img').css({left:0});
};
$('.img').stop().animate({left:-i*600},300);
if (i==$('.img li').length-1) {js实现轮播图最简代码
$('.num li').eq(0).addClass('active').siblings().removeClass('active'); }else{
$('.num li').eq(i).addClass('active').siblings().removeClass('active'); }
},1000)
})
})
以上代码是使⽤js实现的⽆缝轮播效果,代码⽐较简单,所以没有给⼤家注释,如果有疑问欢迎给我留⾔。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论