vue.js實(shí)現(xiàn)的幻燈片功能示例
更新時(shí)間:2019年01月18日 10:20:52 作者:snow_small
這篇文章主要介紹了vue.js實(shí)現(xiàn)的幻燈片功能,結(jié)合實(shí)例形式分析了vue.js實(shí)現(xiàn)幻燈片的相關(guān)樣式、配置、功能等操作技巧,需要的朋友可以參考下
本文實(shí)例講述了vue.js實(shí)現(xiàn)的幻燈片功能。分享給大家供大家參考,具體如下:
1、在父組件中
<slide-show :slides="slides"></slide-show> import SlideShow from '@/components/SlideShow' export default { components: { SlideShow, },
2、在slideshow.vue中
<template> <div class="slide-show" @mouseover="clearInv" @mouseout="runInv"> // 當(dāng)鼠標(biāo)移入的時(shí)候清除,移出的時(shí)候 <div class="slide-img"> <a href="slides[nowIndex].href" rel="external nofollow" > <transition name="slide-trans"> // 使用動畫 <img v-if="isShow" :src="slides[nowIndex].src"> </transition> <transition name="slide-trans-old"> <img v-if="!isShow" :src="slides[nowIndex].src"> </transition> </a> </div> <h2>{{ slides[nowIndex].title }}</h2> <ul class="slide-pages"> <li @click="goto(prevIndex)"><</li> <li v-for="(item, index) in slides" @click="goto(index)"> <a :class="{ on: index === nowIndex}"> {{ index + 1 }} </a> </li> <li @click="goto(nextIndex)">></li> </ul> </div> </template> <script> export default { props: { slides: { // 獲取父組件的屬性 type: Array, default: [] }, inv: { type: Number, default: 1000 } }, data () { return { nowIndex: 0, isShow: true } }, computed: { prevIndex () { // 使用計(jì)算屬性, if (this.nowIndex === 0) { return this.slides.length - 1 } else { return this.nowIndex - 1 } }, nextIndex () { if (this.nowIndex === this.slides.length - 1) { return 0 } else { return this.nowIndex + 1 } } }, methods: { goto (index) { this.isShow = false, setTimeout(() => { // 過10毫秒后, this.isShow = true, this.nowIndex = index }, 10) }, runInv () { // 設(shè)置定時(shí)器 this.timer = setInterval(() => { this.goto(this.nextIndex) }, this.inv) }, clearInv () { clearInterval(this.timer) } }, mounted () { // 加載完后執(zhí)行 this.runInv() } } </script> <style scoped> .slide-trans-enter-active { transition: all .5s; } .slide-trans-enter { transform: translateX(900px); } .slide-trans-old-leave-active { transition: all .5s; transform: translateX(-900px); } .slide-show { position: relative; margin: 15px 15px 15px 0; width: 900px; height: 500px; overflow: hidden; } .slide-show h2 { position: absolute; width: 100%; height: 100%; color: #fff; background: #000; opacity: .5; bottom: 0; height: 30px; text-align: left; padding-left: 15px; } .slide-img { width: 100%; } .slide-img img { width: 100%; position: absolute; top: 0; } .slide-pages { position: absolute; bottom: 10px; right: 15px; } .slide-pages li { display: inline-block; padding: 0 10px; cursor: pointer; color: #fff; } .slide-pages li .on { text-decoration: underline; } </style>
希望本文所述對大家vue.js程序設(shè)計(jì)有所幫助。
相關(guān)文章
VUE學(xué)習(xí)寶典之vue-dialog使用方法
在Vue中dialog對話框是一種常見的組件,用于在用戶與應(yīng)用程序進(jìn)行交互時(shí)顯示信息或收集輸入,這篇文章主要給大家介紹了關(guān)于VUE學(xué)習(xí)寶典之vue-dialog使用方法的相關(guān)資料,需要的朋友可以參考下2024-05-05vue實(shí)現(xiàn)codemirror代碼編輯器中的SQL代碼格式化功能
這篇文章主要介紹了vue實(shí)現(xiàn)codemirror代碼編輯器中的SQL代碼格式化功能,非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08詳解vue2.0 使用動態(tài)組件實(shí)現(xiàn) Tab 標(biāo)簽頁切換效果(vue-cli)
本篇文章主要介紹了詳解vue2.0 使用動態(tài)組件實(shí)現(xiàn) Tab 標(biāo)簽頁切換效果(vue-cli),具有一定的參考價(jià)值,有需要的可以了解下2017-08-08vue項(xiàng)目國際化vue-i18n的安裝使用教程
最近接觸學(xué)習(xí)Vue.js框架結(jié)合Element-ui組件開發(fā)項(xiàng)目。由于最近需要實(shí)現(xiàn)國際化功能,所以下面這篇文章主要介紹了vue項(xiàng)目國際化vue-i18n的使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。2018-03-03Vue表單數(shù)據(jù)修改與刪除功能實(shí)現(xiàn)
本文通過實(shí)例代碼介紹了Vue表單數(shù)據(jù)修改與刪除功能實(shí)現(xiàn),結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友跟隨小編一起看看吧2023-10-10