VUE开发一个图片轮播的组件示例代码
网络编程 2021-07-04 19:20www.168986.cn编程入门
本篇文章主要介绍了VUE开发一个图片轮播的组件示例代码,对图片轮播效果感兴趣的小伙伴们可以参考一下。
本人刚学习vue,用vue做了个图片轮播,狼蚁网站SEO优化我来记录一下,有需要了解VUE开发一个图片轮播的组件的朋友可参考。希望此文章对各位有所帮助。
完成效果图如下
vue开发的思路主要是数据绑定,代码如下
<template> <div ref="root" style="user-select: none;-webkit-user-select: none;overflow: hidden"> <div class="sliderPanel" :class="{transitionAni:ani}" :style="{height:height,transform:translateX}"> <div v-for="item in itemList" class="verticalCenter picbox" :style="{left:item.x+'px'}"> <img :style="{width:width,:}" :src="item.url" style="min-height: 100%"> </div> </div> <div @click="clickLeft" class="arrowLeft verticalCenter horizaCenter"> <img src="./image/arrow.png" style="transform: rotate(180deg)"> </div> <div @click="clickRight" class="arrowRight verticalCenter horizaCenter"> <img src="./image/arrow.png"> </div> <div class="arrowBottom verticalCenter horizaCenter" > <img src="./image/arrow.png" style="transform: rotate(90deg) scale(0.7)"> </div> <div class="sliderBar horizaCenter"> <div v-for="(item,index) in imgArray" @click="clickSliderCircle(index)" class="circle" :class="{circleSelected:item.selected}"> </div> </div> </div> </template> <script> const SCREEN_WIDTH=document.body.clientWidth const SCREEN_HEIGHT=document.body.scrollHeight var left,center,right var selectIndex=0 var count=0 var second=3//slider 时间间隔 var timer=null var ani=null var debugScale=1.0//测试用可调整为小于1 var Direction={left:'left',right:'right'}; var autoDirection=Direction.right var canClick=true export default({ data:function(){ return{ width:'100%', height:SCREEN_HEIGHT+'px', :0, ani:true, translateX:'scale('+debugScale+') translateX(0px)', imgArray:[ { x:0, title1:'现在,在您的实验室', tilte2:'也可以轻松完成无创DNA产前检测', title3:'了解详细流程', click_url:'http://.berrygenomics./products/nextseq-500/500test/', url:'static/image/1.jpg', selected:false, }, { x:0, title1:'Sequel开启新基因组时代', tilte2:'覆盖十余种胎儿染色体疾病,体验升级,呵护加倍', title3:'了解更多', click_url:'http://.berrygenomics./products/nextseq-500/500test/', url:'static/image/2.jpg', }, { x:0, title1:'BRCA1/2全外显子基因突变检测', tilte2:'也可以轻松完成无创DNA产前检测', title3:'了解详细流程', click_url:'http://.berrygenomics./products/nextseq-500/500test/', url:'static/image/3.jpg', }, { x:0, title1:'现在,在您的实验室', tilte2:'也可以轻松完成无创DNA产前检测', title3:'了解详细流程', click_url:'http://.berrygenomics./products/nextseq-500/500test/', url:'static/image/4.jpg', }, { x:0, title1:'现在,在您的实验室', tilte2:'也可以轻松完成无创DNA产前检测', title3:'了解详细流程', click_url:'http://.berrygenomics./products/nextseq-500/500test/', url:'static/image/5.jpg', }, { x:0, title1:'现在,在您的实验室', tilte2:'也可以轻松完成无创DNA产前检测', title3:'了解详细流程', click_url:'http://.berrygenomics./products/nextseq-500/500test/', url:'static/image/6.jpg', }, { x:0, title1:'现在,在您的实验室', tilte2:'也可以轻松完成无创DNA产前检测', title3:'了解详细流程', click_url:'http://.berrygenomics./products/nextseq-500/500test/', url:'static/image/7.jpg', }, { x:0, title1:'现在,在您的实验室', tilte2:'也可以轻松完成无创DNA产前检测', title3:'了解详细流程', click_url:'http://.berrygenomics./products/nextseq-500/500test/', url:'static/image/8.jpg', } ], itemList:[] } }, mounted:function(){ ani=this.$refs.root.querySelector('.sliderPanel') count=this.imgArray.length this.setIndex(selectIndex) //自动滚动切换图片 this.slideAuto(second) }, methods:{ clickLeft:function(){ if(!canClick) return false autoDirection=Direction.left this.slideAuto(second) this.moveLeftAni() canClick=false }, clickRight:function(){ if(!canClick) return false autoDirection=Direction.right this.slideAuto(second) this.moveRightAni() canClick=false }, slideRight:function () { selectIndex++ if(selectIndex+1>count){ selectIndex=0 }else if(selectIndex<0){ selectIndex=count-1 } this.setIndex(selectIndex) }, slideLeft:function () { selectIndex-- if(selectIndex+1>count){ selectIndex=0 }else if(selectIndex<0){ selectIndex=count-1 } this.setIndex(selectIndex) }, clickSliderCircle:function (index) { this.slideAuto(second) this.setIndexPre(index) }, setIndexPre:function (index) { if(!canClick) return false canClick=false if(index==selectIndex)return var leftIndex=index var centerIndex=selectIndex var rightIndex=index for(var i=0;i<count;i++){ if(i==selectIndex){ this.imgArray[i].selected=true }else{ this.imgArray[i].selected=false } } left=this.imgArray[leftIndex] center=this.imgArray[centerIndex] right=this.imgArray[rightIndex] left=JSON.parse(JSON.stringify(left)) right=JSON.parse(JSON.stringify(right)) left.x=-SCREEN_WIDTH center.x=0 right.x=SCREEN_WIDTH left.index=leftIndex center.index=centerIndex right.index=rightIndex this.itemList=[left,center,right] if(index>selectIndex){ autoDirection=Direction.right; +function(obj){ obj.anipted( 'scale('+debugScale+') translateX('+0+'px)', 'scale('+debugScale+') translateX('+-SCREEN_WIDTH+'px)', function(){ obj.setIndex(index) }) }(this) //右移 }else if(index<selectIndex){ //左移 autoDirection=Direction.left; +function(obj){ obj.anipted( 'scale('+debugScale+') translateX('+0+'px)', 'scale('+debugScale+') translateX('+SCREEN_WIDTH+'px)', function(){ obj.setIndex(index) }) }(this) } }, setIndex:function (index) { var leftIndex=index-1 var centerIndex=index var rightIndex=index+1 if(index<=0){ index=0 leftIndex=count-1 centerIndex=index rightIndex=index+1 }else if(index>=count-1){ index=count-1 leftIndex=index-1 centerIndex=index rightIndex=0 } selectIndex=index for(var i=0;i<count;i++){ if(i==selectIndex){ this.imgArray[i].selected=true }else{ this.imgArray[i].selected=false } } left=this.imgArray[leftIndex] center=this.imgArray[centerIndex] right=this.imgArray[rightIndex] left.x=-SCREEN_WIDTH center.x=0 right.x=SCREEN_WIDTH left.index=leftIndex center.index=centerIndex right.index=rightIndex this.itemList=[left,center,right] }, slideAuto:function () { clearInterval(timer); +function (obj) { timer=setInterval(function () { if(autoDirection==Direction.left){ obj.moveLeftAni() }else{ obj.moveRightAni() } },second1000) }(this) }, moveLeftAni:function(){ +function(obj){ obj.anipted( 'scale('+debugScale+') translateX('+0+'px)', 'scale('+debugScale+') translateX('+SCREEN_WIDTH+'px)', function(){ obj.slideLeft() }) }(this) }, moveRightAni:function(){ +function(obj){ obj.anipted( 'scale('+debugScale+') translateX('+0+'px)', 'scale('+debugScale+') translateX('+-SCREEN_WIDTH+'px)', function(){ obj.slideRight() }) }(this) }, anipted:function(fromStr,toStr,callBack){ var handler=null,obj=this handler=function(){ ani.removeEventListener('webkitTransitionEnd',handler,false) callBack() obj.ani=false obj.translateX=fromStr canClick=true } ani.removeEventListener('webkitTransitionEnd',handler,false) ani.addEventListener('webkitTransitionEnd',handler,false) this.ani=true this.translateX=toStr } } }) </script> <style scoped> .transitionAni{ transition: all 0.8s cubic-bezier(.23,1,.32,1); /transition: transform 1s;/ } .arrowLeft{ transition: all 0.4s ease; width: 60px; height: 60px; position: absolute; left: 15px; : 50%; margin-: -30px; background: rgba(0,0,0,0.6); border-radius: 6px; } .arrowLeft:hover{ background: rgba(0,0,0,0.8); transform: scale(1.1); } .arrowRight{ transition: all 0.4s ease; width: 60px; height: 60px; position: absolute; right: 15px; : 50%; margin-: -30px; background: rgba(0,0,0,0.6); border-radius: 6px; } .arrowRight:hover{ background: rgba(0,0,0,0.8); transform: scale(1.1); } .sliderBar{ width:100%;height: auto;position: absolute;bottom: 50px; } .circle{ width: 15px; height: 15px; background: rgba(0,0,0,0.7); border-radius: 50%; display: table-cell; margin-right: 3px; transition: all 0.5s ease; } .circle:hover{ background: #C7015C; transform: scale(1.15); } .circleSelected{ background: #C7015C; transform: scale(1.15); } .arrowBottom{ width: 80px; height: 50px; position: absolute; bottom: -15px; left: 50%; margin-left: -40px; background: #C7015C; border--left-radius: 10px; border--right-radius: 10px; transition: all 0.5s ease-out; } .arrowBottom:hover{ transform: translateY(-10px); background: deeppink; } .picbox{ width: 100%; height: 100%; position: absolute; : 0; overflow: hidden; /transform: scale(0.9);/ /opacity: 0.2;/ transition: all 0.45s ease; } /@keyframes arrowOut-animation {/ /from{/ /transform: translateY(0px);/ /}/ /to{/ /transform: translateY(15px);/ /!width:200px;!/ /}/ /}/ /@keyframes arrowIn-animation {/ /from{/ /transform: translateY(15px);/ /}/ /to{/ /transform: translateY(0px);/ /!height: 200px;!/ /}/ /}/ /.arrowOut{/ /animation: arrowOut-animation;/ /animation-duration: 0.5s;/ /animation-timing-function: ease-out;/ /animation-fill-mode:forwards;/ /}/ /.arrowIn{/ /animation: arrowIn-animation;/ /animation-duration: 0.5s;/ /animation-timing-function:ease-out;/ /animation-fill-mode:forwards;/ /}/ </style>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:js常用的继承--组合式继承
下一篇:canvas仿iwatch时钟效果
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程