common vue-slider
a vue slider component without jQuery.
**events included: ** auto animation,hover on buttons, click the button.
main theory: change the pisition of images container when the currentIndex
changes due to the above events.
tips: stop the automatic animation when the mouse hovers on the button or click the button in case of conflict.
**图片轮播组件事件:**自动轮播、鼠标悬停、左右按钮点击
**总体原理:**通过 currentIndex
的变换来调整显示的图片。
**注意事项:**鼠标悬停或是左右按钮点击都停止自动轮播,避免出现冲突。
附上全部代码,也可以访问我的github
<template>
<div id="slider">
<!-- img-container -->
<div
class="slider-imgcontainer"
ref="container"
>
<img v-for="img in imgs" :src="img.url" alt="img.index">
</div>
<!-- index -->
<div class="slider-buttons">
<span v-for="button in buttons"
class="slider-imgindex"
:class="{ 'slider-imgindex-active': currentIndex === button }"
@mouseover="doTheAnimate(button)"
@mouseout="autoAnimate"
></span>
</div>
<!-- left right button -->
<div class="slider-move">
<span class="to-left" @click="doTheAnimate('left')"><i class="iconfont"></i></span>
<span class="to-right" @click="doTheAnimate('right')"><i class="iconfont"></i></span>
</div>
</div>
</template>
<script>
export default {
name: 'SliderIndex',
data () {
/**
* @property {array} imgs 图片组
* @property {number} currentIndex 当前图片的索引
* @property {array} buttons 索引按钮
* @property {number} timer 计时器
*/
return{
imgs:[
{url: 'https://github.com/WangXBruc/common-vue-slider/blob/master/images/1.jpg', index: 0},
{url: 'https://github.com/WangXBruc/common-vue-slider/blob/master/images/2.jpg', index: 1},
{url: 'https://github.com/WangXBruc/common-vue-slider/blob/master/images/3.jpg', index: 2},
{url: 'https://github.com/WangXBruc/common-vue-slider/blob/master/images/4.jpg', index: 3}],
currentIndex: 0,
buttons: [0,1,2,3],
timer: null
}
},
methods: {
/**
* @method
* @param {string} left 图片容器的left值
* @desc 移动图片容器
*/
move() {
let left = `-${this.currentIndex * 100}%`
this.$refs.container.style.left = left;
},
/**
* @method
* @param {number,string} arg 由Dom传递过来的参数,
* 鼠标悬停事件传递的是number类型;鼠标点击事件传递的是string类型:'left' or 'right'
* @desc 调整currentIndex的值,鼠标点击或是悬停都清空计时器,避免发生冲突
*/
doTheAnimate(arg) {
clearInterval(this.timer);
this.timer = null;
// 鼠标悬停
if( typeof(arg) == 'number' ) {
this.currentIndex = arg;
// 鼠标点击
}else if(typeof(arg) == 'string') {
if(arg && arg === 'left' && this.currentIndex <= 2){
this.currentIndex ++;
}else if(arg && arg === 'right' && this.currentIndex >= 1){
this.currentIndex --;
}
if(!this.timer) {
this.autoAnimate();
}
}
this.move();
},
/**
* @method
* @desc 自动轮播图片
*/
autoAnimate() {
this.timer = setInterval(() => {
if(this.currentIndex === 3){
this.currentIndex = 0;
}else {
this.currentIndex ++ ;
}
this.move();
},4000)
}
},
mounted () {
this.autoAnimate();
}
}
</script>
<style>
*{
margin: 0;
padding: 0;
}
@font-face {
font-family: 'iconfont'; /* project id 847125 */
src: url('//at.alicdn.com/t/font_847125_qhbkbwtxr2.eot');
src: url('//at.alicdn.com/t/font_847125_qhbkbwtxr2.eot?#iefix') format('embedded-opentype'),
url('//at.alicdn.com/t/font_847125_qhbkbwtxr2.woff') format('woff'),
url('//at.alicdn.com/t/font_847125_qhbkbwtxr2.ttf') format('truetype'),
url('//at.alicdn.com/t/font_847125_qhbkbwtxr2.svg#iconfont') format('svg');
}
.iconfont {
font-family:"iconfont";
font-size:16px;
font-style:normal;
}
#slider{
position: relative;
width: 100%;
overflow: hidden;
height: 300px;
}
.slider-imgcontainer {
position: absolute;
left: 0;
width: 400%;
height: 300px;
transition: left .5s linear;
}
img {
width: 25%;
height: 300px;
}
.slider-buttons {
position: absolute;
width: 30%;
left: 35%;
bottom: 10px;
display: flex;
align-items: center;
justify-content: space-between;
}
.slider-imgindex {
cursor: pointer;
width: 14px;
height: 14px;
margin: 0 10px;
background-color: rgba(255, 248, 248, 0.98);
border-radius: 7px;
transition: width .3s linear;
}
.slider-imgindex-active {
width: 60px;
}
.slider-move {
position: absolute;
top: 40%;
height: 20%;
width: 100%;
display: flex;
justify-content: space-between;
align-items: center;
}
.slider-move span {
cursor: pointer;
text-align: center;
color: #fff;
line-height: 60px;
width: 50px;
background-color: rgba(8,1,1,0.62);
}
.slider-move span:hover{
background-color: rgba(8,1,1,0.9);
}
</style>
来源:CSDN
作者:RUCwang
链接:https://blog.csdn.net/RUCwang/article/details/82795553