vue可以简单的就实现一个轮播图的基础功能,不仅重复用,且可抽离出来作为一个公共组件。
html和js部分
<template> <div class="img-box" ref="img-box" :style="{width: styles.width, height: styles.height}" > <div v-for="(item, index) in imgList" :key="index" class="img-item" :ref="'img-item-' + index" :class="{'active': index === active}" > <img :src="item" style="width:100%" :style="{height: styles.height}" /> </div> <div class="img-position" v-if="isShowPosition" > <template v-for="(item, index) in imgList"> <span :key="index" class="img-position-item" :ref="'img-position-' + index" :class="[ {'active': index === active}, isCircle ? 'circle' : '', isNums ? 'nums' : '' ]" @click="clickSpan(index)" > {{isNums ? index + 1 : ''}} </span> </template> </div> <div class="left-btn" v-if="isShowLeftOrRightBtn" @click="clickBtn('left')" > <i class="iconfont roll-zuo"></i> </div> <div class="right-btn" v-if="isShowLeftOrRightBtn" @click="clickBtn('right')" > <i class="iconfont roll-you"></i> </div> </div> </template> <script> export default { name: 'Roll', props: { imgList: { // 图片列表 src数组 type: Array, default: () => [] }, isShowPosition: { // 是否显示下方小圆点 type: Boolean, default: true }, positionInner: { // 圆点内容 type: String, default: 'circle' // 默认圆点,可选值 circle => 圆点 num => 数字 both => 圆点+数字 }, isShowLeftOrRightBtn: { // 是否显示左右按钮 type: Boolean, default: true }, duration: { // 切换间隔 type: [Number, String], default: 3000 }, styles: { // 自定义轮播图片宽高 默认500*300 type: Object, default: () => { return { width: '500px', height: '300px' } } } }, data () { return { active: 0, // 当前轮播图片 timer: null // 定时器 } }, computed: { isCircle () { return ['circle', 'both'].includes(this.positionInner) }, isNums () { return ['num', 'both'].includes(this.positionInner) } }, updated () { if (this.timer) this.clearTimer() this.setTimer() }, created () { this.setTimer() }, methods: { clickSpan (index) { this.clearTimer() this.active = index }, clickBtn (arg) { this.clearTimer() if (arg === 'left') { this.active = this.active - 1 < 0 ? this.imgList.length - 1 : this.active - 1 } else { this.active = this.active + 1 === this.imgList.length ? 0 : this.active + 1 } this.setTimer() }, setTimer () { this.timer = setInterval(() => { this.clickBtn('right') }, Number(this.duration)) }, clearTimer () { clearInterval(this.timer) this.timer = null } } } </script>
css样式部分
<style scoped> @import url('//at.alicdn.com/t/font_1451815_senarwrqu6.css'); * { margin: 0; padding: 0; } .img-box { position: relative; margin: 0 auto; } .img-item { height: 100%; width: 100%; opacity: 0; position: absolute; top: 0; right: 0; left: 0; bottom: 0; z-index: -5; text-align: center; } .img-item.active { z-index: 0; opacity: 1; transition: .3s; } .img-position { position: absolute; bottom: 5px; left: 50%; display: flex; transform: translate(-50%, 0); } .img-position-item { display: inline-block; width:10px; height:10px; box-sizing: border-box; cursor: pointer; } .img-position-item.circle { border-radius: 50%; border: 1px solid #606266; } .img-position-item.nums { width: 18px; height: 18px; display: flex; justify-content: center; align-items: center; color: #606266; font-size:14px; } .img-position-item:hover, .img-position-item.active { border-color: #d1d2d3; color: #d1d2d3; transition: .3s; } .img-position-item + .img-position-item { margin-left: 10px; } .left-btn, .right-btn { position: absolute; top: 50%; bottom: 0; width: 20px; height: 30px; display: flex; justify-content: center; align-items: center; cursor: pointer; color: #d1d2d3; font-size: 20px; transform: translate(0, -50%); } .left-btn:hover, .right-btn:hover { color: #fff; transition: .3s; } .left-btn { left: 5px; } .right-btn { right: 5px; } </style>
用上述方式只是用Vue作为一个组件,可以现在一个轮播图比较基础的部分,大家可以多多参照。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/127614.html
摘要:很久没上掘金发现草稿箱里存了好几篇没发的文章最近梳理下发出来往期面试官系列如何实现深克隆面试官系列的实现面试官系列前端路由的实现面试官系列基于数据劫持的双向绑定优势所在面试官系列你为什么使用前端框架前言设计前端组件是最能考验开发者基本功的测 很久没上掘金,发现草稿箱里存了好几篇没发的文章,最近梳理下发出来 往期 面试官系列(1): 如何实现深克隆 面试官系列(2): Event Bus...
摘要:在中新建组件许文瑞正在吃屎。。。。在中添加如下代码三歌手组件开发歌手首页开发数据获取数据获取依旧从音乐官网获取歌手接口创建我们和以前一样,利用我们封装的等发放,来请求我们的接口,返回给。 Vue-Music 跟学一个网课老师做的仿原生音乐APP跟学的笔记,记录点滴,也希望对学习vue初学小伙伴有点帮助 showImg(https://segmentfault.com/img/remot...
摘要:基于等开发一款移动端音乐,界面参考了安卓版的网易云音乐布局适配常见移动端。图标使用阿里巴巴图标库,中间的唱片旋转动画使用了实现。搜索功能实现功能搜索歌手歌单歌曲热门搜索数据节流上拉刷新保存搜索记录。 基于 Vue(2.5) + vuex + vue-router + vue-axios +better-scroll + Scss + ES6 等开发一款移动端音乐 WebApp,UI ...
阅读 498·2023-03-27 18:33
阅读 706·2023-03-26 17:27
阅读 606·2023-03-26 17:14
阅读 575·2023-03-17 21:13
阅读 498·2023-03-17 08:28
阅读 1753·2023-02-27 22:32
阅读 1259·2023-02-27 22:27
阅读 2065·2023-01-20 08:28