幽灵资源网 Design By www.bzswh.com
本文记录的是在html中写两个img实现多张图片的无缝滚动,供大家参考,具体内容如下
html结构如下:
<div class="wrap"> <ul class="list"> <li> <img src="/UploadFiles/2021-04-02/img0.png">css样式不再详述,想要使图片位置发生变化,方法有很多。此次用的是定位,修改.list的left值。
js代码如下:
(function(){ var list=document.querySelector(".list"); var imgs=document.querySelectorAll("img"); var prev=document.querySelector(".prev"); var next=document.querySelector(".next"); var imgW=css(imgs[0],"width");//使用封装好的css()获取img的宽度 var now=0; var imgData=["img/img0.png", "img/img1.png", "img/img2.png", "img/img3.png",]; prev.onclick=function(){ //找出接下来要显示的图片的下标 var prev=(now-1+imgData.length)%imgData.length; //因为是从右往左运动,当前显示的应在右侧,即将显示的在左侧 imgs[0].src=imgData[prev]; imgs[1].src=imgData[now]; //使用封装好的css()设置list的位置 css(list,"left",-imgW); //使用封装好的运动函数来控制图片移动 startMove(list,{left:0},2000,"easeOut"); now=prev; } next.onclick=function(){ var next=(now+1)%imgData.length; imgs[0].src=imgData[now]; imgs[1].src=imgData[next]; css(list,"left",0); startMove(list,{left:-imgW},2000,"easeOut"); now=next; } })();到这一步,大体功能已经实现。但是当频繁点击上一张/下一张按钮时,会发现图片在设定的运动时间闪换。解决这个问题有两个办法:1.减小运动时间,如将2000ms改为500ms,2.限定定时器只能开一个。
在上述js代码基础上增加以下代码,以上一张操作为例,增加定时器个数判断。
var isMove=false;//记录定时器开关状态 prev.onclick=function(){ if(isMove){ return; } ....上述上一张操作js代码 isMove=true; startMove(list,{left:-imgW},2000,"easeOut",function(){ isMove=false; }); }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
幽灵资源网 Design By www.bzswh.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
幽灵资源网 Design By www.bzswh.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。