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

溫馨提示×

溫馨提示×

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

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

vue3中使用swiper遇到的問題怎么解決

發布時間:2023-04-18 17:48:59 來源:億速云 閱讀:181 作者: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遇到的問題怎么解決”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“vue3中使用swiper遇到的問題怎么解決”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

新津县| 宜宾市| 台东市| 浦北县| 石渠县| 白玉县| 新宁县| 海宁市| 潞城市| 囊谦县| 绥芬河市| 丰县| 横山县| 阜平县| 伊宁市| 长白| 修水县| 新绛县| 安吉县| 中牟县| 仙桃市| 开鲁县| 平阳县| 漯河市| 四平市| 永登县| 东乡县| 台安县| 景宁| 竹溪县| 阳高县| 阳山县| 承德县| 澄江县| 聊城市| 游戏| 鄂州市| 平利县| 白城市| 易门县| 张掖市|