vue使用swiper的時(shí)候第二輪事件不會觸發(fā)問題
使用swiper的時(shí)候第二輪事件不會觸發(fā)
首先說明導(dǎo)致這樣的結(jié)果的原因:官方解釋是輪播在循環(huán)輪播的時(shí)候他是前面復(fù)制一份后面復(fù)制一份,這樣看起來就是無縫滾動,但是在復(fù)制的時(shí)候不會復(fù)制事件,所以會有事件不會觸發(fā)
解決這種有兩種方法
- 第一種loop為false,這樣沒有復(fù)制元素自然也不存在復(fù)制事件這一說法
- 第二種重新寫options
第一步定義ref跟重新定義options


data里面是不需要的
計(jì)算屬性里面寫個(gè)事件swiper事件是原swiper自帶的在點(diǎn)擊的時(shí)候computed會自動監(jiān)聽跟watch差不多(緩存),然后讓其指向我們當(dāng)前使用的swiper讓其有原生的方法,swiper里面有個(gè)on屬性 里面是綁定事件讓其執(zhí)行swiper方法,返回當(dāng)前dom,常用的獲取id的方式
– clickedSlide當(dāng)前輪播dom
– activeIndexloop模式下注意該值會被加上復(fù)制的slide數(shù)
– realIndex與activeIndex不同的是,在loop模式下不會將復(fù)制的塊的數(shù)量計(jì)算在內(nèi)。
常用獲取的方法 其余看文檔
切記:最后要將optins返回 然后綁定值options
computed: {
swiper() {
return this.$refs.mySwiper.swiper
},
swiperOption() {
let option = {
slidesPerView: 5,
// height: 'auto',
autoplay: {
delay: 3000,
stopOnLastSlide: false,
/* 觸摸滑動后是否繼續(xù)輪播 */
disableOnInteraction: false
},
spaceBetween: 1,
// observer: true,//修改swiper自己或子元素時(shí),自動初始化swiper
// observeParents: true,//修改swiper的父元素時(shí),自動初始化swiper
direction: "vertical", //設(shè)置垂直滾動方向
speed: 800,//滾動速度
grabCursor: true,
loop: true,//循環(huán)滾動
on: {
click: (swiper) => {
console.log(this.date[this.swiper.clickedSlide.getAttribute('data-index')].userId);
this.$store.commit("showDialog5", this.date[this.swiper.clickedSlide.getAttribute('data-index')].userId);
},
},
}
return option
}
},

swiper點(diǎn)擊事件無效的問題
現(xiàn)象
添加在swiper-slide里面的點(diǎn)擊事件有時(shí)能點(diǎn)擊有時(shí)不能點(diǎn)擊
分析
只有在設(shè)置了loop:true的情況下才會出現(xiàn)這個(gè)問題
原因
swiper通過復(fù)制dom節(jié)點(diǎn)來實(shí)現(xiàn)無限滾動,但沒有復(fù)制元素上綁定的事件
解決方法
在輪播配置里面定義事件,即options里面,這樣的話可以解決不能點(diǎn)擊的問題
但有時(shí)候需求會復(fù)雜一點(diǎn),比如需要點(diǎn)擊輪播圖里面特定元素,做出不同的響應(yīng)事件,這時(shí)候就需要做一些另外的工作來輔助完成。
首先要將 preventLinksPropagation設(shè)置成false,防止冒泡。
然后通過判斷點(diǎn)擊的元素的類名來響應(yīng)不同的事件,這個(gè)時(shí)候,我們可能需要給事件傳遞參數(shù),但是需要傳遞的參數(shù)是通過v-for生成的,如何傳遞,這里我的做法是將參數(shù)放到元素的自定義屬性里面 然后再獲取自定義屬性。
<swiper ref="mySwiper" :options="swiperOption">
swiperOption: {
? ? ? ? spaceBetween: 10,
? ? ? ? loop: true,
? ? ? ? slidesPerView: 'auto',
? ? ? ? loopedSlides: 3,
? ? ? ? slidesOffsetBefore: (document.body.clientWidth * 0.2) / 2,
? ? ? ? preventLinksPropagation: false,
? ? ? ? on: {
? ? ? ? ? click: (v) => {
? ? ? ? ? ? const item = {
? ? ? ? ? ? ? a: v.target.getAttribute('data-a'),
? ? ? ? ? ? ? b: v.target.getAttribute('data-b'),
? ? ? ? ? ? ? c: v.target.getAttribute('data-c')
? ? ? ? ? ? }
? ? ? ? ? ? switch (v.target.className) {
? ? ? ? ? ? ? case 'a':
? ? ? ? ? ? ? ? this.handlegg(0)
? ? ? ? ? ? ? ? break
? ? ? ? ? ? ? case 'b':
? ? ? ? ? ? ? ? this.handlegg(1, item)
? ? ? ? ? ? ? ? break
? ? ? ? ? ? ? case 'c':
? ? ? ? ? ? ? ? this.handlegg(2, item)
? ? ? ? ? ? ? ? break
? ? ? ? ? ? }
? ? ? ? ? }
? ? ? ? }
? ? ? }輪播圖里面某元素
<div v-else class="xxx"> ?<div? ? ? class="c" ? ? :data-a="item.a"? ? ? :data-b="item.b"? ? ? :data-c="item.c" ? ? ></div> ? <div>立即開通</div> </div>
問題解決。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue3自定義組件之v-model實(shí)現(xiàn)父子組件雙向綁定
這篇文章主要介紹了vue3自定義組件之v-model實(shí)現(xiàn)父子組件雙向綁定方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
Vue使用provide各種傳值后inject獲取undefined的問題及解決
這篇文章主要介紹了Vue使用provide各種傳值后inject獲取undefined的問題及解決,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
使用vue的v-for生成table并給table加上序號的實(shí)例代碼
這篇文章主要介紹了使用vue的v-for生成table并給table加上序號的相關(guān)資料,需要的朋友可以參考下2017-10-10
vue實(shí)現(xiàn)pdf文檔在線預(yù)覽功能
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)pdf文檔在線預(yù)覽功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11
詳解Vue中是如何實(shí)現(xiàn)cache緩存的
這篇文章分享一個(gè)比較有意思的東西,那就是Vue中如何實(shí)現(xiàn)cache緩存的,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-07-07

