vue使用swiper插件實(shí)現(xiàn)輪播圖的示例
hello大家好,最近我在做一個(gè)仿餓了么的項(xiàng)目,我會(huì)將我的項(xiàng)目經(jīng)驗(yàn)同步到這里,與大家分享!
vue - 使用swiper插件實(shí)現(xiàn)輪播圖
下載安裝: npm install swiper --save
Msite.vue的HTML部分:
<!--在頁(yè)面msite_nav導(dǎo)航部分使用swiper-->
<div class="swiper-container">
<div class="swiper-wrapper">
<div class="swiper-slide">1</div>
<div class="swiper-slide">2</div>
<div class="swiper-slide">3</div>
</div>
<!-- swiper輪播圖圓點(diǎn) -->
<div class="swiper-pagination"></div>
</div>
script部分引入并初始化:
<script>
import Swiper from 'swiper'
//同時(shí)引入swiper的 css文件
import 'swiper/dist/css/swiper.min.css'
export default {
//注意要在頁(yè)面加載完成之后(mounted)再進(jìn)行swiper的初始化
mounted () {
//創(chuàng)建一個(gè)swiper實(shí)例來實(shí)現(xiàn)輪播
new Swiper('.swiper-container', {
autoplay: true,
// 如果需要分頁(yè)器
pagination: {
el: '.swiper-pagination',
clickable: true
}
})
}
}
</script>
需要注意的是:在引入css文件的時(shí)候,因?yàn)榘姹静煌?,引入的方式也不同,否則會(huì)因找不到相對(duì)應(yīng)的css文件而報(bào)錯(cuò),比如最新的版本
import 'swiper/swiper-bundle.min.css'
具體用法參考[Swiper官方文檔]
有一個(gè)需要特別注意的是,需要在請(qǐng)求數(shù)據(jù)之后創(chuàng)建swiper實(shí)例
使用watch與$nextTick解決輪播的Bug
分頁(yè)器Swiper其實(shí)應(yīng)該是在輪播列表顯示(即categorys數(shù)組有了數(shù)據(jù))以后才初始化。
最開始categorys為空數(shù)組,有了數(shù)據(jù)才會(huì)顯示輪播列表,而要監(jiān)視categorys的數(shù)據(jù)變化,就要用到watch。
// 新建watch 監(jiān)聽categorys
watch: {
categorys (value) { // categorys數(shù)組中有數(shù)據(jù)了
// 但界面還沒有異步更新
}
}
// 刪除mounted中的new Swiper...代碼
但其實(shí)state里的狀態(tài)數(shù)據(jù)改變(categorys接收數(shù)據(jù))與異步更新界面(顯示輪播列表)是兩個(gè)步驟。所以需要等一等,界面完成異步更新后才可以進(jìn)行Swiper的初始化。
// 使用setTimeout可以實(shí)現(xiàn)效果, 但是時(shí)機(jī)不準(zhǔn)確
setTimeout(() => {
// 創(chuàng)建一個(gè)Swiper實(shí)例對(duì)象, 來實(shí)現(xiàn)輪播
new Swiper('.swiper-container', {
autoplay: true,
// 如果需要分頁(yè)器
pagination: {
el: '.swiper-pagination',
clickable: true
}
})
}, 100)
利用vm.$nextTick( [callback] )來實(shí)現(xiàn)等待界面完成異步更新就立即創(chuàng)建Swiper對(duì)象
// 在修改數(shù)據(jù)之后立即使用它,然后等待 DOM 更新。
this.$nextTick(() => {
// 一旦完成界面更新, 立即執(zhí)行回調(diào)
new Swiper('.swiper-container', {
autoplay: true,
pagination: {
el: '.swiper-pagination',
clickable: true
}
})
以上就是vue使用swiper插件實(shí)現(xiàn)輪播圖的示例的詳細(xì)內(nèi)容,更多關(guān)于vue使用swiper插件實(shí)現(xiàn)輪播圖的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue利用Mixin輕松實(shí)現(xiàn)代碼復(fù)用
Mixin,中文翻譯為"混入",在Vue中是一種非常有用的功能,可以解決許多開發(fā)中的常見問題,下面就讓我們一起深入了解一下Mixin在Vue中解決了哪些問題吧2023-06-06
vue前端實(shí)現(xiàn)驗(yàn)證碼登錄功能
這篇文章主要介紹了vue前端實(shí)現(xiàn)驗(yàn)證碼登錄功能,登錄時(shí)圖形驗(yàn)證通過三種方法結(jié)合實(shí)例代碼給大家講解的非常詳細(xì), 通過實(shí)例代碼介紹了vue登錄時(shí)圖形驗(yàn)證碼功能的實(shí)現(xiàn),感興趣的朋友一起看看吧2023-12-12
vue?頂部消息橫向滾動(dòng)通知效果實(shí)現(xiàn)
系統(tǒng)頂部展示一個(gè)橫向滾動(dòng)的消息通知,就是消息內(nèi)容從右往左一直滾動(dòng),這篇文章主要介紹了vue頂部消息橫向滾動(dòng)通知,需要的朋友可以參考下2024-02-02
Vue引入jquery實(shí)現(xiàn)平滑滾動(dòng)到指定位置
這篇文章主要介紹了Vue引入jquery實(shí)現(xiàn)平滑滾動(dòng)到指定位置的效果,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2018-05-05
vue組件表單數(shù)據(jù)回顯驗(yàn)證及提交的實(shí)例代碼
今天小編就為大家分享一篇vue組件表單數(shù)據(jù)回顯驗(yàn)證及提交的實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08
詳解基于 axios 的 Vue 項(xiàng)目 http 請(qǐng)求優(yōu)化
這篇文章主要介紹了詳解基于 axios 的 Vue 項(xiàng)目 http 請(qǐng)求優(yōu)化,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-09-09
vue+elementui+vuex+sessionStorage實(shí)現(xiàn)歷史標(biāo)簽菜單的示例代碼
本文主要介紹了vue+elementui+vuex+sessionStorage實(shí)現(xiàn)歷史標(biāo)簽菜單的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12

