中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2023-05-12 09:37:41 來源:億速云 閱讀:180 作者:iii 欄目:編程語言

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

一、安裝swiper

使用npm install swiper安裝swpier插件

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

二、使用swiper

直接按照官網的引用方法,項目會報錯

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

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

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 屬性同時使用;

三、echarts+swiper

項目背景

需要在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遇到的問題如何解決

到此,相信大家對“vue3中使用swiper遇到的問題如何解決”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南昌市| 离岛区| 凭祥市| 桐城市| 淮北市| 定远县| 广灵县| 轮台县| 蒙阴县| 玉田县| 丹凤县| 永康市| 贞丰县| 双辽市| 南充市| 柳林县| 罗山县| 台中县| 伊春市| 东平县| 福贡县| 东城区| 铜山县| 乐平市| 浦江县| 奉新县| 辽源市| 西城区| 和硕县| 洛浦县| 措美县| 凤凰县| 响水县| 曲周县| 阆中市| 内乡县| 阜平县| 商城县| 油尖旺区| 津市市| 泰宁县|