關(guān)于同時(shí)使用swiper和echarts遇到的問(wèn)題及解決方法
項(xiàng)目背景
場(chǎng)景:需要在swiper中每個(gè)輪播項(xiàng)中展示包含不同的echarts,并開(kāi)啟loop:true循環(huán)
swiper: 5.3.6
vue-awesome-swiper: 4.0.4
echarts: 5.2.1
問(wèn)題一
開(kāi)啟loop:true, 首先遇到echarts失效不能正常渲染的問(wèn)題,果斷百度發(fā)現(xiàn)是因?yàn)殚_(kāi)啟loop:true時(shí),swiper會(huì)在前后復(fù)制同樣的slide保證循環(huán)效果,這樣以來(lái)初始化時(shí)使用的ID就不是唯一的了,導(dǎo)致echarts初始化無(wú)效了。
解決辦法
// 通過(guò)class獲取dom,并在循環(huán)時(shí)初始化,為了保證echarts初始化時(shí)dom已經(jīng)更新渲染,加一個(gè)setTimeout函數(shù) ?setTimeout(() => { ?// 解決繪圖復(fù)制出來(lái)的echarts沒(méi)有顯示的問(wèn)題 ? const myEchart = document.getElementsByClassName('liquidfill') ? let chart = null ? for (const item of myEchart) { ? ? ? item.setAttribute('_echarts_instance_', '') ? ? ? chart = echarts.init(item) ? ? ? chart.setOption(option) ? } })
問(wèn)題二
- 當(dāng)我沉浸在剛才解決的顯示問(wèn)題被解決的喜悅之中時(shí),嘩。。。一盆涼水襲面而來(lái),echarts包括標(biāo)簽上的點(diǎn)擊事件竟然失效了,當(dāng)然不是所有的都失效,但也很*疼啊,查找資料后發(fā)現(xiàn)和第一個(gè)問(wèn)題類似,同樣slide復(fù)制后click事件并沒(méi)有每一個(gè)都綁定,導(dǎo)致點(diǎn)擊失效。
- 解決辦法
查找資料發(fā)現(xiàn)swiper有一個(gè)click-slide的點(diǎn)擊事件,該事件可接收(index, realIndex)參數(shù)。
<swiper ref="mySwiper" class="my-swipe" :options="swiperOptions" @click-slide="goToPage"></swiper>` goToPage(index, realIndex) { // index 當(dāng)前slide下標(biāo)包含復(fù)制的slide // realIndex 真實(shí)的下表 根據(jù)這個(gè)下標(biāo)執(zhí)行對(duì)應(yīng)方法即可。 }
到此這篇關(guān)于關(guān)于同時(shí)使用swiper和echarts遇到的問(wèn)題及解決方法的文章就介紹到這了,更多相關(guān)使用swiper和echarts遇到問(wèn)題內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript 數(shù)組(list)添加/刪除的實(shí)現(xiàn)
這篇文章主要介紹了javascript 數(shù)組(list)添加/刪除,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12使用ionic(選項(xiàng)卡欄tab) icon(圖標(biāo)) ionic上拉菜單(ActionSheet) 實(shí)現(xiàn)通訊錄界面切換實(shí)例
這篇文章主要介紹了使用ionic(選項(xiàng)卡欄tab) icon(圖標(biāo)) ionic上拉菜單(ActionSheet) 實(shí)現(xiàn)通訊錄界面切換實(shí)例代碼,需要的朋友可以參考下2017-10-10JavaScript實(shí)現(xiàn)模態(tài)框拖拽效果
這篇文章主要介紹了通過(guò)JavaScript實(shí)現(xiàn)模態(tài)框拖拽的效果,以及鼠標(biāo)松開(kāi),可以停止拖動(dòng)模態(tài)框移動(dòng)等功能,感興趣的小伙伴可以了解一下2021-12-12解決layui的使用以及針對(duì)select、radio等表單組件不顯示的問(wèn)題
今天小編就為大家分享一篇解決layui的使用以及針對(duì)select、radio等表單組件不顯示的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09JavaScript CSS 通用循環(huán)滾動(dòng)條
核心是 position:relative;,才能讓其內(nèi)部的 ul 以絕對(duì)定位,通過(guò)改變 top 值實(shí)現(xiàn)向上移位置。2009-10-10localStorage設(shè)置有效期和過(guò)期時(shí)間的簡(jiǎn)單方法
眾所周知前端三大緩存,cookie,sessionStorage,localStorage,下面這篇文章主要給大家介紹了關(guān)于localStorage設(shè)置有效期和過(guò)期時(shí)間的相關(guān)資料,需要的朋友可以參考下2022-02-02JS實(shí)現(xiàn)選項(xiàng)卡插件的兩種寫法(jQuery和class)
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)選項(xiàng)卡插件的兩種寫法:jQuery和class,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12javascript實(shí)現(xiàn)貪吃蛇小練習(xí)
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)貪吃蛇的小練習(xí),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07JS實(shí)現(xiàn)簡(jiǎn)單移動(dòng)端鼠標(biāo)拖拽
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)簡(jiǎn)單移動(dòng)端鼠標(biāo)拖拽,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07小程序中canvas的drawImage方法參數(shù)使用詳解
這篇文章主要介紹了小程序中canvas的drawImage方法參數(shù)使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07