简单实现轮播图片切换效果(基于vue)

编程入门 行业动态 更新时间:2024-10-08 10:54:25

简单实现轮播图片切换<a href=https://www.elefans.com/category/jswz/34/1770448.html style=效果(基于vue)"/>

简单实现轮播图片切换效果(基于vue)

思路: 

一: 将vue的框架封装在function中,在界面刷新时调用,将要轮播的图片存放在data中,还有下面的列表也分别保存在data中的一个数组中,然后每隔一段时间进行自动切换的函数写在methods中,注意函数要调用的话,就要在生命周期函数中调用,不然的话就没有用,点击这里了解生命周期函数详细知识。
二: 认识到这里需要的是setinterval()、而不是setimeout()函数:
etTimeout()和setInterval()经常被用来处理延时和定时任务。setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式,而setInterval()则可以在每隔指定的毫秒数循环调用函数或表达式,直到clearInterval把它清除。
setTimeout()只执行一次,而setInterval可以多次调用。

三: n的设置:方便我们进行操作,比如循环到第几个,下面的小黑点也相应的变色,并且控制循环播放,当n等于数组的个数时,自动置0,从头开始。
四: html页面写好大的框架后,用v-for来控制,需要注意的是用v-for的时候一定要加上:key,
五: v-show的使用
六: 这里使用了字体库,所以要提前下载字体库。

直接上代码了

<body>
<!--页面容器--><div class="index-content" id="my"><div class="banner"><img  v-for="(v,i) in img " :key="i" :src="v" v-show="i==n"/>   <div class="banner-circle"><ul><li  v-for="(v,i) in img " :key="i" :class="i==n ?'selected':''"></li>  </ul> </div></div></div></body>

js

window.onload = function(){new Vue({el:"#my",data:{img:["img/banner1.jpg","img/banner2.jpg","img/banner3.jpg","img/banner4.jpg","img/banner5.jpg"],n:2},methods:{fun:function(){//setInterval(函数体,时间)setInterval(this.play,2000)},play:function(){this.n++;if(this.n == this.img.length){this.n = 0;}}},mounted:function(){    //生命周期  钩子函数   挂载完成this.fun()}})
}

css

*{margin:0;padding:0;
}
ul {list-style-type:none;
}
body {font-size: 14px;background: #fff;overflow-y:scroll;overflow-x:hidden;
}
html,body {max-width:720px;height:100%;margin:0 auto;
}/*index*/
.index-content .banner {position: relative;
}
.index-content .banner .banner-circle {position: absolute;bottom: 5px;left: 0;right: 0;color: #fff;
}
.index-content .banner .banner-circle li{display:inline-block;background: rgba(0,0,0,.3);border-radius: 50%;padding:5px;margin:2px;
}
.index-content .banner .banner-circle ul {text-align: center;
}
.index-content .banner .banner-circle .selected {background: rgba(0,0,0,.8);
}
.index-content .banner img {width: 100%;margin: 0;padding: 0;
}
/*index-category*/
.index-content .index-category {margin-top: 5%;
}
.index-content .index-category .category {width: 50%;float:left;text-align:center;
}
.index-content .index-category .category .iconfont {font-size: 40px;display:inline-block;padding: 10%;border-radius: 50%;color:#fff;border: 3px solid #f9f9f9;box-shadow: 0px 0px 6px rgba(0,0,0,.5);
}
.index-content .index-category .category .iconfont{background: #92d85c;
}
.index-content .index-category .category:nth-child(2) .iconfont{background: #f60;
}
.index-content .index-category .category:nth-child(4) .iconfont{background: #f00;
}
.index-content .index-category .category label {display: block;padding: 10% 0;color: #999;
}
/*index-category end*/

 

更多推荐

简单实现轮播图片切换效果(基于vue)

本文发布于:2024-02-07 04:48:46,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1753336.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:效果   简单   图片   vue

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!