JS实现纵向轮播图(初级版)
程序员文章站
2022-06-15 15:51:12
本文实例为大家分享了js实现纵向轮播图的具体代码,供大家参考,具体内容如下
描述:
纵向buton或者底部数字控制轮播,可以实现自动轮播(注释了,使用的话将其注释消掉),核心知识是...
本文实例为大家分享了js实现纵向轮播图的具体代码,供大家参考,具体内容如下
描述:
纵向buton或者底部数字控制轮播,可以实现自动轮播(注释了,使用的话将其注释消掉),核心知识是数据驱动图像的透明度达到效果。
效果:
代码:
js文件:
/* * 工厂模式 * */ var method=(function () { return { loadimage:function (arr,callback) { var img=new image(); img.arr=arr; img.list=[]; img.num=0; img.callback=callback; // 如果dom对象下的事件侦听没有被删除掉,将会常驻堆中 // 一旦触发了这个事件需要的条件,就会继续执行事件函数 img.addeventlistener("load",this.loadhandler); img.self=this; img.src=arr[img.num]; }, loadhandler:function (e) { this.list.push(this.clonenode(false)); this.num++; if(this.num>this.arr.length-1){ this.removeeventlistener("load",this.self.loadhandler); this.callback(this.list); return; } this.src=this.arr[this.num]; }, $c:function (type,parent,style) { var elem=document.createelement(type); if(parent) parent.appendchild(elem); for(var key in style){ elem.style[key]=style[key]; } return elem; } } })();
html文件:
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>title</title> <style> #con,#bgimg,#bgimg img { width: 100%; height: 500px; } #con { position: relative; margin: auto; } #bgimg{ position: absolute; } #bgimg img{ opacity: 1; transition: all 1s; position: absolute; left:0; top:0; } #iconimg { position: absolute; width: 120px; right: 50px; top:30px; } #iconimg img { margin-top: 8px; border: 2px solid #ffa50000; transition: all 0.5s; } </style> <script src="js/method.js"></script> </head> <body> <div id="con"> <div id="bgimg"> <img src="img/a.jpeg"> </div> <div id="iconimg"> <img src="img/icon_a.jpeg"> <img src="img/icon_b.jpeg"> <img src="img/icon_c.jpeg"> <img src="img/icon_d.jpeg"> <img src="img/icon_e.jpeg"> </div> </div> <script> var bgimg,iconimg,previmg,imglist;//定义大图 小图的盒子(5个img) var n=0;//图像标记 var arr=["img/a.jpeg","img/b.jpeg","img/c.jpeg","img/d.jpeg","img/e.jpeg"];//图片设置为数组形式 传参 init(); function init() { method.loadimage(arr,loadfinishhandler)//预加载 } function loadfinishhandler(list) {//预加载赋值 imglist=list; bgimg=document.getelementbyid("bgimg"); iconimg=document.getelementbyid("iconimg"); for(var i=0;i<iconimg.children.length;i++){ iconimg.children[i].num=i; iconimg.children[i].addeventlistener("click",clickhandler); } changeborder(iconimg.firstelementchild); } setinterval(autoimg,3000); function autoimg() {//自动轮播效果 n++; //全局变量 用于控制当前轮播顺序 if (n>4) n=0; changeimg(n);//大图轮播 changeborder(iconimg.children[n]);//小图外边框轮播 设置第几个 弄懂参数代表含义 } function clickhandler(e) { e =e || window.event; changeborder(this); n=this.num; changeimg(this.num); } function changeborder(elem) { if(previmg){ previmg.style.border="2px solid #ffa50000"; } previmg=elem; previmg.style.border="2px solid #ffa500"; } function changeimg(index) { if(bgimg.children.length>1){ bgimg.lastelementchild.remove(); } bgimg.lastelementchild.style.opacity="0"; imglist[index].style.opacity="1"; bgimg.insertbefore(imglist[index],bgimg.firstelementchild); } </script> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: JavaScript实现滑动门效果
下一篇: Jquery事件和特效