首先来分析一下轮播图效果的实现原理:
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
用一张图来帮助理解:
修改ul元素的left值很简单ul.style.left=设定值,就可以了,但我们想有一个滑动的效果,那我们需要用setInterval来实现
最后的效果如下:
动图不能录制太大CSDN有2M的限制_(:зゝ∠)_
下面放代码
script部分
<script> window.onload= 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.onclick= function () { if(index==0){ index=2; iSpeed=-20; }else{ index--; iSpeed=10; } goRoll(); //img.style.left=-index*870+'px'; }; next.onclick= function () { if(index==2){ index=0; iSpeed=20; }else{ index++; iSpeed=-10; } goRoll(); //img.style.left=-index*870+'px'; }; } </script>
html放一下
<div class="panel center-panel bc_rice"> <div class="panel-box"> <a class="prev-btn" id="prev"></a> <div class="img-box"> <div class="list-box"> <ul class="img-list" id="imgList"> <li> <img src="/UploadFiles/2021-04-02/c1.jpg">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;}因为我写了一整个页面都放出来没啥用,所以我只截取了用到的部分。
现在还是有些问题的,比如如果点击过快是会出问题的,这个以后看看能不能完善。以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。