vue3中使用swiper遇到的问题如何解决

本篇内容主要讲解“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,如:



其中:

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遇到的问题如何解决
网站路径:http://myzitong.com/article/gpgghs.html