如何在vue2项目中使用Swiper5组件


一、背景

之前做的业务需要在vue2中插入一个Swiper组件,但是尝试了很多次都一直失败,官方文档和能搜索到的方法也对我不太有用,总是报错!后来在大佬的视频(https://www.bilibili.com/video/BV1TY4y1z7Z8/?spm_id_from=333.337.search-card.all.click&vd_source=d45e199a358edbf199494ee895775ab3)中才明白是vue版本和Swiper版本没有对应上的问题。

所以,如果你是在维护一个基于vue2的项目,并想在其中插入Swiper组件,可以继续阅读这篇文章。


一、安装Swiper5

目前Swiper已经更新到8了,但Swiper7、Swiper8主要针对vue3。在vue2项目中,Swiper5相对来说更好使用。

首先右键node_modules,在集成终端中打开并输入如下命令:

npm i swiper@5

二、导入css和js

中文教程-Swiper使用方法的第一步告诉我们需要引入css和js,但官方给我们的例子并不是在vue中的使用,仅仅是在html静态页面中的使用:
Swiper使用方法
虽然中文教程的下拉栏中也有在vue中使用Swiper,但讲的是Swiper7/Swiper8在vue3中的使用,不适用于vue2项目。

在vue2项目中,我们需要在该组件的使用页面按如下代码导入css和js文件:

//导入js
import Swiper from "swiper";
//引入css
import "swiper/css/swiper.min.css";

三、粘贴html结构

Swiper7的默认容器是’.swiper’,Swiper6之前是’.swiper-container’。

//记得将swiper修改过来
<div class="swiper-container">
    <div class="swiper-wrapper">
        <div class="swiper-slide">Slide 1</div>
        <div class="swiper-slide">Slide 2</div>
        <div class="swiper-slide">Slide 3</div>
    </div>
    <!-- 如果不需要以下功能,注释即可 -->
    <!-- 如果需要分页器 -->
    <div class="swiper-pagination"></div>
    
    <!-- 如果需要导航按钮 -->
    <div class="swiper-button-prev"></div>
    <div class="swiper-button-next"></div>
    
    <!-- 如果需要滚动条 -->
    <div class="swiper-scrollbar"></div>
</div>

将类名为swiper-slide盒子中的Slide1、Slide2、Slide3修改为自己想展示的轮播内容即可。实际应用中一般使用axios获取到数据后再用v-for遍历,今天这篇先不展开了,下一篇写。

四、初始化Swiper

这一步用到了Swiper的真实DOM结构,在vue项目里应该写在生命周期mounted(){}中。

说明文档
这里不需要像说明文档一样var mySwiper了,因为创建变量但不使用会导致vue报错。正确代码如下:

mounted() {
    new Swiper(".swiper-container", {
      loop: true, // 循环模式选项
      slidesPerView: 3,
      centeredSlides: true,
      centeredSlidesBounds: true,
      // 如果需要分页器
      pagination: {
        el: ".swiper-pagination",
      },
    });
  },

其中的参数设置可以根据自己的需求配置选项。比如我这里想做centeredSlidesBounds这个效果:

API文档
所以我按API文档的要求配置了这些参数:
API文档
做完这一步后Swiper组件就可以在vue2项目中使用了!

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TeresaPeng_zju

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值