制作轮播切换效果html,原生JS实现图片轮播切换效果

首先来分析一下轮播图效果的实现原理:

1、父元素作为显示窗口,大小固定超出部分隐藏,即设置overflow:hidden;

2、子元素存放图片列表用ul,ul固定定位,参照为父元素,即父元素position:relative;ul元素position:absolute;

3、一个li即一张图片的宽度为父元素的显示宽度

4、初始时,ul的left为0,这时第一张图片即第一个li显示

5、点击下一张按钮,将整个ul左移,使第二个li对齐父元素的左边框,此时ul的left为负的一个li的宽度

6、点击上一张按钮,将整个ul右移

7、对特殊情况进行处理,即第一张图时点上一张,最后一张图时点下一张

第一张图时点上一张,我们滚动到最后一张图,整个ul左移,即把left值改为负的n-1张图的宽度;

最后一张图时点下一张,我们滚到第一张图的位置,整个ul右移,即把left值改为0

用一张图来帮助理解:

c6561cc71fac5994350f7d1f911b2506.png

修改ul元素的left值很简单ul.style.left=设定值,就可以了,但我们想有一个滑动的效果,那我们需要用setInterval来实现

最后的效果如下:

b21af478c605f15bc6a976bb822d9646.gif

动图不能录制太大CSDN有2M的限制_(:зゝ∠)_

下面放代码

script部分

window.οnlοad= function () {

var nav=document.getElementById("nav").getElementsByTagName("li");

var img=document.getElementById("imgList");

var prev=document.getElementById("prev");

var next=document.getElementById("next");

var index=0;//当前图片序列号

var timer;//定时器名字

var iSpeed=-10;//滚动的速度

function goRoll(){

timer=setInterval(function () {

img.style.left=img.offsetLeft+iSpeed+'px';

var stop=-index*870+'px';//当达到目标位置是停止定时器

if(img.style.left==stop){

iSpeed=-10;

clearInterval(timer);

}

},10)

}

// 上一张和下一张点击效果

prev.οnclick= function () {

if(index==0){

index=2;

iSpeed=-20;

}else{

index--;

iSpeed=10;

}

goRoll();

//img.style.left=-index*870+'px';

};

next.οnclick= function () {

if(index==2){

index=0;

iSpeed=20;

}else{

index++;

iSpeed=-10;

}

goRoll();

//img.style.left=-index*870+'px';

};

}

html放一下

  • c1.jpg

  • c2.jpg

  • c3.jpg

shadow1.png

CSS放一下

.fb{font-weight:bold;}

.c_fff{color:#fff;}

.f24{font-size:24px;}

.f72{font-size:72px;}

.lh40{line-height:40px;}

.bc_brown{background:#533d3b;}

.bc_green{background:#74cdab;}

.bc_rice{background:#ecf1c8;}

.bc_beige{background:#d1d5b0;}

.mT10{margin-top:10px;}

.mT20{margin-top:20px;}

.mT30{margin-top:30px;}

.mT40{margin-top:40px;}

.tc{text-align:center;}

.dblock{display:block;}

.clearfix:after{content:'';display:block;visibility:hidden;clear:both;line-height:0;font-size:0;}

.clearfix{zoom:1;}

html,body{width:100%;height:100%;font-size:14px;font-family:Myriad Pro;color:#433c3c;}

div,p,a,span,ul,li,em{margin:0;padding:0;}

ul li{list-style-type:none;}

a:hover{cursor:pointer;}

/*main-panel*/

.main-panel{width:100%;min-width:1030px;margin:0 auto;}

.main-panel .panel{width:100%;}

.main-panel .panel .line{width:100%;height:23px;background:url('../img/line.png');}

.main-panel .panel .panel-box{width:960px;height:100%;margin:0 auto;overflow:hidden;position:relative;}

.center-panel{height:510px;position:relative;}

.center-panel .panel-box{width:990px;z-index:1000;}

.center-panel .center-line{height:76px;position:absolute;width:100%;top:200px;z-index:10;}

.center-panel .panel-box a{width:51px;height:82px;display:block;position:absolute;top:200px;}

.center-panel .prev-btn{background:url('../img/Button-left.png');left:0;}

.center-panel .next-btn{background:url('../img/Button-right.png');right:0;}

.center-panel .img-box{width:940px;height:366px;background:url('../img/shadow.png');margin-top:45px;margin-left:10px;overflow:hidden;}

.center-panel .list-box{width:870px;height:334px;margin:16px auto;overflow:hidden;position:relative;}

.center-panel .img-list{width:4000px;height:334px;position:absolute;left:0;}

.center-panel .img-list li{width:870px;height:100%;float:left;}

因为我写了一整个页面都放出来没啥用,所以我只截取了用到的部分。

现在还是有些问题的,比如如果点击过快是会出问题的,这个以后看看能不能完善。

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

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值