Skip to content

Instantly share code, notes, and snippets.

@mchome
Last active April 9, 2018 06:48
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save mchome/febe71b3d81ae7e40dfbd95132a22d16 to your computer and use it in GitHub Desktop.
Save mchome/febe71b3d81ae7e40dfbd95132a22d16 to your computer and use it in GitHub Desktop.
<template>
<div id="app">
<swiper :images="images"></swiper>
</div>
</template>
<script>
import swiper from "./components/vue-swiper";
export default {
name: "App",
components: {
swiper
},
data() {
return {
images: [
"https://images.unsplash.com/photo-1493134799591-2c9eed26201a?ixlib",
"https://images.pexels.com/photos/290595/pexels-photo-290595.jpeg",
"http://ak8.picdn.net/shutterstock/videos/15138448/thumb/4.jpg",
"https://previews.123rf.com/images/gropgrop/gropgrop1510/gropgrop151000188/47475636-dubai-city-skyline-detailed-silhouette-hand-drawn-engraved-vector-illustration.jpg",
""
]
};
}
};
</script>
<style>
#app {
font-family: "Avenir", Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
body {
margin: 0;
}
</style>
<template>
<div class="swiper">
<div class="btnLeft" @click="previewBtn"><</div>
<div class="swiper-images"
id="swiper-image"
:style="{transform: 'translateX(-' + currentIndex*20 + 'rem)'}">
<div class="swiper-image"
v-for="image in imageList"
:key="image.id"
:style="{backgroundImage: 'url(' + image + ')'}">
</div>
</div>
<div class="btnRight" @click="nextBtn">></div>
<div class="indicator">
<div @click="currentIndex = index" :class="{'indicator-item-selected': currentIndex === index}" class="indicator-item" v-for="(item, index) in images" :key="index"></div>
</div>
</div>
</template>
<script>
export default {
name: "swiper",
props: {
images: Array,
autoplay: {
type: Boolean,
default: () => true
},
duration: {
type: Number,
default: () => 3000
}
},
data() {
return {
currentIndex: 0,
interval: 0
};
},
computed: {
imageList: function() {
const firstImage = this.images[0];
const lastImage = this.images[this.images.length - 1];
let images = this.images.slice();
images.unshift(lastImage);
images.push(firstImage);
return images;
}
},
methods: {
previewBtn: function() {
if (this.currentIndex === 0) this.currentIndex = this.images.length;
this.currentIndex -= 1;
},
nextBtn: function() {
if (this.currentIndex === this.images.length - 1) this.currentIndex = -1;
this.currentIndex += 1;
},
setAutoPlay: function() {
if (this.autoplay) {
this.interval = setInterval(this.nextBtn, this.duration);
}
},
stopAutoPlay: function() {
if (this.autoplay) {
clearInterval(this.interval);
}
}
},
mounted: function() {
this.$nextTick(function() {
document
.getElementById("swiper-image")
.addEventListener("mouseover", ev => this.stopAutoPlay());
document
.getElementById("swiper-image")
.addEventListener("mouseout", ev => {
this.stopAutoPlay();
this.setAutoPlay();
});
this.setAutoPlay();
});
}
};
</script>
<style scoped>
.swiper {
display: flex;
flex-direction: row;
align-items: center;
overflow: hidden;
width: 30rem;
}
.btnLeft,
.btnRight {
display: inline-flex;
z-index: 10;
background-color: rgba(255, 255, 255, 0.6);
height: 2.5rem;
width: 1.5rem;
position: absolute;
justify-content: center;
align-items: center;
cursor: default;
user-select: none;
backdrop-filter: blur(5px);
}
.btnRight {
left: 28.5rem;
}
.swiper-images {
display: inline-flex;
flex-direction: row;
flex-wrap: nowrap;
z-index: 0;
height: 15rem;
width: 30rem;
position: relative;
left: -15rem;
transition: transform 0.5s ease-in-out;
}
.swiper-image {
min-width: 20rem;
background-size: cover;
background-repeat: no-repeat;
cursor: pointer;
}
.indicator {
position: absolute;
height: 1.5rem;
width: 6rem;
margin-left: 12.5rem;
margin-top: 5.5rem;
display: flex;
flex-direction: row;
justify-content: space-around;
align-items: center;
z-index: 10;
}
.indicator-item {
height: 0.7rem;
width: 0.7rem;
background-color: rgba(255, 255, 255, 0.6);
border-radius: 50%;
cursor: pointer;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.indicator-item:hover {
box-shadow: 1px 1px 4px 0px rgba(0, 0, 0, 0.25),
4px 6px 10px 0px rgba(0, 0, 0, 0.22);
}
.indicator-item-selected {
background-color: orange;
}
</style>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment