中文字幕第五页-中文字幕第页-中文字幕韩国-中文字幕最新-国产尤物二区三区在线观看-国产尤物福利视频一区二区

Vue中如何實現輪播圖效果

這篇文章將為大家詳細講解有關Vue中如何實現輪播圖效果,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

網站建設哪家好,找創新互聯建站!專注于網頁設計、網站建設、微信開發、微信小程序、集團企業網站建設等服務項目。為回饋新老客戶創新互聯還提供了喀什免費建站歡迎大家使用!

Vue 過渡

Vue 的過渡系統是內置的,在元素從 DOM 中插入或移除時自動應用過渡效果。

過渡的實現要在目標元素上使用 transition 屬性,具體實現參考Vue2 過渡

下面例子中我們用到列表過渡,可以先學習一下官方的例子

要同時渲染整個列表,比如使用 v-for,我們需要用到 <transition-group> 組件

Vue 輪播圖

我們先看這樣一個列表

<ul>
 <li v-for="list in slideList">
  <img :src="list.image" :alt="list.desc">
 </li>
</ul>

這個列表要從實例(見文章末尾)中獲取了三張圖片,要使其中的圖片產生輪播,我們需要用 <transition-group> 組件替換其中的 ul 標簽,從而實現過渡組件的功能,完整的組件 DOM 內容如下,下面分段解釋一下

<div class="carousel-wrap" id="carousel">
  // 輪播圖列表
  <transition-group tag="ul" class='slide-ul' name="list">
   <li v-for="(list,index) in slideList" :key="index" v-show="index===currentIndex" @mouseenter="stop" @mouseleave="go">
    <a :href="list.clickUrl" rel="external nofollow" rel="external nofollow" rel="external nofollow" >
     <img :src="list.image" :alt="list.desc">
    </a>
   </li>
  </transition-group>
  // 輪播圖位置指示
  <div class="carousel-items">
   <span v-for="(item,index) in slideList.length" :class="{'active':index===currentIndex}" @mouseover="change(index)"></span>
  </div>
</div>

對應的數據結構如下:

data: {
  slideList: [
    {
      "clickUrl": "#",
      "desc": "nhwc",
      "image": "http://dummyimage.com/1745x492/f1d65b"
    },
    {
      "clickUrl": "#",
      "desc": "hxrj",
      "image": "http://dummyimage.com/1745x492/40b7ea"
    },
    {
      "clickUrl": "#",
      "desc": "rsdh",
      "image": "http://dummyimage.com/1745x492/e3c933"
    }
  ],
  currentIndex: 0,
  timer: ''
},

在使用 v-for 時,應給對應的元素綁定一個 key 屬性,相當于 index 標識,在 <transition-group> 組件中,key 是必須的,這樣一個輪播圖的 DOM 結構就完成了

接下來我們看看輪播函數的實現,再來看組件中的 li 元素

<li v-for="(list,index) in slideList" :key="index">
  <a :href="list.clickUrl" rel="external nofollow" rel="external nofollow" rel="external nofollow" >
   <img :src="list.image" :alt="list.desc">
  </a>
</li>

上面通過 v-for 渲染了 li 列表,并在其中插入了包含可點擊跳轉的圖片,接下來看看如何實現輪播,輪播圖的樣式直接在后面給出大家 sass 代碼,父元素 ul 設置 position: relative;overflow: hidden 后,li 大小設為和父元素相同,absolute 定位固定在父元素中,要讓 li 按照順序顯示,需要用到 v-show 或 v-if 處理,通過 index 值來改變當前顯示的 li ,本例 v-show 綁定條件 index===currentIndex,用定時器改變 currentIndex 實現輪播

<li v-for="(list,index) in slideList" :key="index" v-show="index===currentIndex" @mouseenter="stop" @mouseleave="go">
  <a :href="list.clickUrl" rel="external nofollow" rel="external nofollow" rel="external nofollow" >
   <img :src="list.image" :alt="list.desc">
  </a>
</li>

實例中的方法:

//在下個tick執行等待圖片加載完成后再
this.$nextTick(() => {
 this.timer = setInterval(() => {
  this.autoPlay()
 },4000)
}),
go() {
 this.timer = setInterval(() => {
  this.autoPlay()
 },4000)
},
stop() {
 clearInterval(this.timer)
 this.timer = null
},
change(index) {
 this.currentIndex = index
},
autoPlay() {
 this.currentIndex++
 if (this.currentIndex > this.slideList.length - 1) {
  this.currentIndex = 0
 }
}

DOM 中為每個輪播 li 元素綁定事件 @mouseenter="stop" @mouseleave="go" 事件,使輪播鼠標移入時停止,移出時再次開始。

輪播圖現在位置指示,綁定類名 active 改變顏色,綁定 change() 方法,鼠標移到指示點時跳轉輪播圖

<div class="carousel-items">
 <span v-for="(item,index) in slideList.length" :class="{'active':index===currentIndex}" @mouseover="change(index)"></span>
</div>

sass 樣式代碼

.carousel-wrap {
 position: relative;
 height: 453px;
 width: 100%;
 overflow: hidden;
 // 刪除
 background-color: #fff;
}

.slide-ul {
 width: 100%;
 height: 100%;
 li {
  position: absolute;
  width: 100%;
  height: 100%;
  img {
   width: 100%;
   height: 100%;
  }
 }
}

.carousel-items {
 position: absolute;
 z-index: 10;
 top: 380px;
 width: 100%;
 margin: 0 auto;
 text-align: center;
 font-size: 0;
 span {
  display: inline-block;
  height: 6px;
  width: 30px;
  margin: 0 3px;
  background-color: #b2b2b2;
  cursor: pointer;
 }
 .active {
  background-color: $btn-color;
 }
}

滑動動畫設置,知識點詳見 Vue 教程中的 過渡 css 類名

.list-enter-active {
 transition: all 1s ease;
 transform: translateX(0)
}

.list-leave-active {
 transition: all 1s ease;
 transform: translateX(-100%)
}

.list-enter {
 transform: translateX(100%)
}

.list-leave {
 transform: translateX(0)
}

完整 Vue 實例如下

new Vue({
 el: '#carousel',
 data: {
  slideList: [
    {
      "clickUrl": "#",
      "desc": "nhwc",
      "image": "http://dummyimage.com/1745x492/f1d65b"
    },
    {
      "clickUrl": "#",
      "desc": "hxrj",
      "image": "http://dummyimage.com/1745x492/40b7ea"
    },
    {
      "clickUrl": "#",
      "desc": "rsdh",
      "image": "http://dummyimage.com/1745x492/e3c933"
    }
  ],
  currentIndex: 0,
  timer: ''
 },
 methods: {
  this.$nextTick(() => {
   this.timer = setInterval(() => {
    this.autoPlay()
   },4000)
  }) 
  go() {
   this.timer = setInterval(() => {
    this.autoPlay()
   },4000)
  },
  stop() {
   clearInterval(this.timer)
   this.timer = null
  },
  change(index) {
   this.currentIndex = index
  },
  autoPlay() {
   this.currentIndex++
   if (this.currentIndex > this.slideList.length - 1) {
    this.currentIndex = 0
   }
  }
 }
})

關于“Vue中如何實現輪播圖效果”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

名稱欄目:Vue中如何實現輪播圖效果
鏈接地址:http://www.2m8n56k.cn/article36/jjdcsg.html

成都網站建設公司_創新互聯,為您提供商城網站網站設計軟件開發網站維護網頁設計公司

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:[email protected]。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

搜索引擎優化
主站蜘蛛池模板: 窝窝人体色 | 亚洲网站视频在线观看 | 在线亚洲黄色 | 中文字幕国产视频 | 福利社色| 亚州一级毛片在线 | 国产欧美在线观看不卡 | 99热碰 | a级毛片免费观看网站 | 中国一级毛片 | 亚洲男人天堂手机版 | 欧美在线一级毛片视频 | 国产亚洲精品一区二区 | 日本三级特黄 | 国产深夜福利在线观看网站 | 国产99精品一区二区三区免费 | 狠狠色狠狠色综合久久一 | 美女脱了内裤张开腿让男人桶网站 | 嫩草影院ncyy在线观看 | 日本在线免费观看视频 | 热99re久久精品2久久久 | 国产精品三级在线播放 | 99久久一区| 日韩一区二区三 | 日韩精品网| 精品亚洲成a人在线播放 | 99国产精品久久久久久久成人热 | 尤物tv已满18点击进入 | 成人www视频网站免费观看 | 国产精品久久久精品三级 | 碰碰久久 | 国产欧美久久久另类精品 | 日韩在线精品视频 | 91日本在线视频 | 欧美人牲囗毛片 | 欧美在线一级视频 | 国产a级高清版毛片 | 欧美成人激情在线 | 网红主播大尺度精品福利视频 | 欧美高h视频 | 一级片视频免费观看 |