您好,登錄后才能下訂單哦!
本篇內容主要講解“vue3中使用swiper遇到的問題如何解決”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“vue3中使用swiper遇到的問題如何解決”吧!
使用npm install swiper安裝swpier插件
npm install swiper -s // @9.2.0 // 或者安裝指定版本 npm install swiper@8.4.7 -s
直接按照官網的引用方法,項目會報錯
解決方法:
引入的組件使用以下路徑
import { Swiper, SwiperSlide } from "swiper/vue/swiper-vue"; import "swiper/swiper.min.css";
有時還需要使用一些其他的組件API,如:
<template> <swiper class="swpier" :modules="modules" :slides-per-view="3" :space-between="50" loop="true" direction="horizontal" navigation :autoplay="{ delay: 2000, disableOnInteraction: false, pauseOnMouseEnter: true, }" :pagination="{ clickable: true }" :scrollbar="{ draggable: true }" @swiper="onSwiper" @slideChange="onSlideChange" > <swiper-slide>Slide 1</swiper-slide> <swiper-slide>Slide 2</swiper-slide> <swiper-slide>Slide 3</swiper-slide> <swiper-slide>Slide 4</swiper-slide> <swiper-slide>Slide 5</swiper-slide> </swiper> </template> <script> // Navigation: 方向箭頭:向左,向右 /* Pagination: 輪播小圓點 clickable: 如果為true,則單擊分頁按鈕將跳轉到對應的slide。僅適用于項目符號分頁類型 */ /* Scrollbar: 滾動條 draggable: 設置為true可使滾動條可拖動,從而控制滑塊位置 */ /* AutoPlay: 自動輪播 delay: 轉換之間的延遲(毫秒)。如果未指定此參數,將禁用自動播放 disableOnInteraction:設置為false,用戶交互(滑動)后自動播放不會被禁用,每次交互后都會重新啟動 pauseOnMouseEnter:啟用后,指針(鼠標)在Swiper容器上輸入時將暫停自動播放。 */
import { Navigation, Pagination, Scrollbar, A11y, Autoplay } from "swiper"; import { Swiper, SwiperSlide } from "swiper/vue/swiper-vue"; import "swiper/swiper.min.css"; import "swiper/modules/navigation/navigation.min.css"; import "swiper/modules/pagination/pagination.min.css"; import "swiper/modules/scrollbar/scrollbar.min.css"; import "swiper/modules/autoplay/autoplay.min.css"; export default { components: { Swiper, SwiperSlide, }, setup() { const onSwiper = (swiper) => { console.log(swiper); }; const onSlideChange = () => { console.log("slide change"); }; return { onSwiper, onSlideChange, modules: [Navigation, Pagination, Scrollbar, A11y, Autoplay], }; }, }; </script> <style> .swpier { height: 200px; } .swiper-slide { width: 100px; line-height: 40px; font-size: 30px; text-align: center; border: 1px solid pink; } </style>
其中:
loop: 是否循環播放:true/false
direction:輪播方向"horizontal"/“vertical”,默認"horizontal"
slides-per-view:控制一次顯示幾張輪播圖
space-between: 每張輪播圖之間的距離,該屬性不可以和margin 屬性同時使用;
項目背景
需要在swiper的每個輪播項中展示并包含不同的echarts,且開啟loop:true循環
“echarts”: “^5.4.0”
“swiper”: “^9.2.0”
問題描述:
開啟loop:true后,第一個和最后一個echarts無法正常渲染
原因:
loop:true后swiper會在前后復制同樣的slide保證循環效果,初始化時使用的ID就不是唯一的了,導致echarts初始化無效了
解決方法:
// 通過class獲取dom,并在循環時初始化,為了保證echarts初始化時dom已經更新渲染,加一個setTimeout函數 setTimeout(() => { const myEchart = document.getElementsByClassName(classname); let chart = null; Array.prototype.forEach.call(myEchart, function (element, i, arr) { element.setAttribute("_echarts_instance_", ""); chart = echarts.init(element); console.log(arr); chart.setOption(optionArr[i]); }); })
或者使用for (let i = 0; i < myEchart.length; i++) {}循環遍歷dom
注意:這里不是能用for (let i in myEchart) {},否則會報錯如下:
到此,相信大家對“vue3中使用swiper遇到的問題如何解決”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。