亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在Vue2中使用slide輪播圖組件

發布時間:2021-06-11 17:19:30 來源:億速云 閱讀:338 作者:Leah 欄目:web開發

今天就跟大家聊聊有關如何在Vue2中使用slide輪播圖組件,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

<v-carousel :slideData="slideData" :height="450" :begin="0" :interval="3000" :dot="true" :arrow="true"></v-carousel>

如何在Vue2中使用slide輪播圖組件

話不多說直接上源碼

輪播圖應用頁面 \components\public\home.vue

<template>
 <div id="home">
  <v-carousel :slideData="slideData" :height="450" :begin="0" :interval="3000" :dot="true" :arrow="true"></v-carousel>
 </div>
</template>
<script>
 import carousel from "./public/carousel";
 export default {
  name: 'home',
  data() {
   return {
    slideData:[
     {
      title:'這是一個Vue輪播圖組件',
      src:require('../assets/pic1.jpg'),
      url:'/show/499'
     },
     {
      title:'這是一個Vue輪播圖組件',
      src:require('../assets/pic2.jpg'),
      url:'/show/499'
     },
     {
      title:'這是一個Vue輪播圖組件',
      src:require('../assets/pic3.jpg'),
      url:'/show/499'
     },
     {
      title:'這是一個Vue輪播圖組件',
      src:require('../assets/pic4.jpg'),
      url:'/show/499'
     },
     {
      title:'這是一個Vue輪播圖組件',
      src:require('../assets/pic5.jpg'),
      url:'/show/499'
     },
    ]
   }
  },
  components:{
   'v-carousel': carousel,
  },
  methods: {
  },
  mounted() {
  }
 }
</script>
<style scoped>
</style>

輪播圖組件頁面 src\components\public\carousel.vue 

<template>
 <div id="carousel">
  <div class="carousel" ref="carousel" v-bind:>
   <transition-group tag="ul" class="slide clearfix" :name="transitionName" >
    <li v-for="(item,index) in slideData" :key="index" v-show="index==beginValue" v-bind: >
     <router-link :to="item.url">
      <img :src="item.src">
      <div class="title">{{item.title}}</div>
     </router-link>
    </li>
   </transition-group>
   <div class="up" @click="up" v-show="arrow"></div>
   <div class="next" @click="next" v-show="arrow"></div>
   <div class="slideDot" v-show="dot">
    <span v-for="(item,index) in slideData" :class="{active:index==beginValue}" @click="change(index)" :key="index"></span>
   </div>
  </div>
 </div>
</template>
<script>
 export default {
  name: "carousel",
  data(){
   return{
    setInterval:'',
    beginValue:0,
    transitionName:'slide'
   }
  },
  beforeDestroy() {
   // 組件銷毀前,清除監聽器
   clearInterval(this.setInterval);
  },
  methods:{
   change(key){
    if(key>(this.slideData.length-1)){
     key=0;
    }
    if(key<0){
     key=this.slideData.length-1;
    }
    this.beginValue=key;
   },
   autoPlay(){
    //console.log(this.$refs.carousel.getBoundingClientRect().width);
    this.transitionName='slide';
    this.beginValue++
    if(this.beginValue>=this.slideData.length){
     this.beginValue=0;
     return;
    }
   },
   play(){
    this.setInterval=setInterval(this.autoPlay,this.interval)
   },
   mouseOver(){ //鼠標進入
    //console.log('over')
    clearInterval(this.setInterval)
   },
   mouseOut(){ //鼠標離開
    //console.log('out')
    this.play()
   },
   up(){ //上一頁
    --this.beginValue;
    this.transitionName='slideBack';
    this.change(this.beginValue);
   },
   next(){ //下一頁
    ++this.beginValue;
    this.transitionName='slide';
    this.change(this.beginValue);
   }
  },
  mounted(){
   var box = this.$refs.carousel; //監聽對象
   box.addEventListener('mouseover',()=>{
    this.mouseOver();
   })
   box.addEventListener('mouseout',()=>{
    this.mouseOut();
   })
   this.beginValue=this.begin;
   this.play();
  },
  props:{
   height:{
    type: Number,
    default: 600
   },
   dot:{
    type: Boolean,
    default: true
   },
   arrow:{
    type: Boolean,
    default: true
   },
   interval:{
    type: Number,
    default: 5000
   },
   begin:{
    type: Number,
    default: 0
   },
   slideData:{
    type: Array,
    default: function () {
     return [];
    }
   }
  }
 }
</script>
<style scoped>
 .slide{position: relative;margin: 0;padding: 0; overflow: hidden;width: 100%; height:450px;}
 .slide li{list-style: none;position: absolute;width: 100%; height:450px;}
 .slide li img{width: 100%; height:450px;cursor:pointer}
 .slide li .title{position: absolute; left:0; bottom: 0; padding: 10px 20px; width: 100%; background: rgba(0,0,0,.35);color: #fff;font-size: larger; text-align: center}
 .slideDot{position: absolute;z-index: 999; bottom: 60px;right:15px; }
 .slideDot span{display: inline-block; width: 30px; height: 7px; background:rgba(255,255,255,.65); margin-left: 5px;}
 .slideDot span.active{background:rgba(255,255,255,1);}
 .up,.next{position: absolute; left:0; top: 50%; margin-top: -32px; cursor: pointer; width:64px;height: 64px;
  background-repeat: no-repeat;
  background-position: 50% 50%;
 }
 .up{background-image: url("");}
 .next{left: auto;right:0;background-image: url("");}
 .up:hover{background-color: rgba(0,0,0,.3)}
 .next:hover{background-color: rgba(0,0,0,.3)}
 /*進入過渡生效時的狀態*/
 .slide-enter-active{
  transform:translateX(0);
  transition: all 1s ease;
 }
 /*進入開始狀態*/
 .slide-enter{
  transform:translateX(-100%);
 }
 /*離開過渡生效時的狀態*/
 .slide-leave-active{
  transform:translateX(100%);
  transition: all 1s ease;
 }
 /*離開過渡的開始狀態*/
 .slide-leave{
  transform:translateX(0);
 }
 /*進入過渡生效時的狀態*/
 .slideBack-enter-active{
  transform:translateX(0);
  transition: all 1s ease;
 }
 /*進入開始狀態*/
 .slideBack-enter{
  transform:translateX(100%);
 }
 /*離開過渡生效時的狀態*/
 .slideBack-leave-active{
  transform:translateX(-100%);
  transition: all 1s ease;
 }
 /*離開過渡的開始狀態*/
 .slideBack-leave{
  transform:translateX(0);
 }
</style>

看完上述內容,你們對如何在Vue2中使用slide輪播圖組件有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武乡县| 奉节县| 涿州市| 稷山县| 永吉县| 裕民县| 宜黄县| 秦皇岛市| 芦山县| 正蓝旗| 南岸区| 锡林浩特市| 福安市| 易门县| 嘉荫县| 安溪县| 河池市| 江孜县| 大同市| 舒兰市| 龙江县| 浙江省| 义乌市| 苏尼特右旗| 上饶县| 文安县| 米脂县| 四川省| 通州市| 凯里市| 孟津县| 丰顺县| 建始县| 积石山| 谢通门县| 洪雅县| 平南县| 汤原县| 岳阳市| 会同县| 双牌县|