溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

vue3中使用swiper遇到的問題如何解決

發(fā)布時(shí)間:2023-05-12 09:37:41 來源:億速云 閱讀:175 作者:iii 欄目:編程語言

本篇內(nèi)容主要講解“vue3中使用swiper遇到的問題如何解決”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“vue3中使用swiper遇到的問題如何解決”吧!

一、安裝swiper

使用npm install swiper安裝swpier插件

npm install swiper -s // @9.2.0
// 或者安裝指定版本
npm install swiper@8.4.7 -s

二、使用swiper

直接按照官網(wǎng)的引用方法,項(xiàng)目會(huì)報(bào)錯(cuò)

vue3中使用swiper遇到的問題如何解決

解決方法:
引入的組件使用以下路徑

import { Swiper, SwiperSlide } from "swiper/vue/swiper-vue";
import "swiper/swiper.min.css";

有時(shí)還需要使用一些其他的組件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: 輪播小圓點(diǎn)
clickable: 如果為true,則單擊分頁按鈕將跳轉(zhuǎn)到對(duì)應(yīng)的slide。僅適用于項(xiàng)目符號(hào)分頁類型
*/
/* Scrollbar: 滾動(dòng)條
draggable: 設(shè)置為true可使?jié)L動(dòng)條可拖動(dòng),從而控制滑塊位置
*/
/* AutoPlay: 自動(dòng)輪播
delay: 轉(zhuǎn)換之間的延遲(毫秒)。如果未指定此參數(shù),將禁用自動(dòng)播放
disableOnInteraction:設(shè)置為false,用戶交互(滑動(dòng))后自動(dòng)播放不會(huì)被禁用,每次交互后都會(huì)重新啟動(dòng)
pauseOnMouseEnter:?jiǎn)⒂煤?,指針(鼠?biāo))在Swiper容器上輸入時(shí)將暫停自動(dòng)播放。
*/
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: 是否循環(huán)播放:true/false
direction:輪播方向"horizontal"/“vertical”,默認(rèn)"horizontal"
slides-per-view:控制一次顯示幾張輪播圖
space-between: 每張輪播圖之間的距離,該屬性不可以和margin 屬性同時(shí)使用;

三、echarts+swiper

項(xiàng)目背景

需要在swiper的每個(gè)輪播項(xiàng)中展示并包含不同的echarts,且開啟loop:true循環(huán)

“echarts”: “^5.4.0”
“swiper”: “^9.2.0”

問題描述:

開啟loop:true后,第一個(gè)和最后一個(gè)echarts無法正常渲染

原因:

loop:true后swiper會(huì)在前后復(fù)制同樣的slide保證循環(huán)效果,初始化時(shí)使用的ID就不是唯一的了,導(dǎo)致echarts初始化無效了

解決方法:

// 通過class獲取dom,并在循環(huán)時(shí)初始化,為了保證echarts初始化時(shí)dom已經(jīng)更新渲染,加一個(gè)setTimeout函數(shù)
 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++) {}循環(huán)遍歷dom

注意:這里不是能用for (let i in myEchart) {},否則會(huì)報(bào)錯(cuò)如下:

vue3中使用swiper遇到的問題如何解決

到此,相信大家對(duì)“vue3中使用swiper遇到的問題如何解決”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI