vue3 使用swiper轮播组件
本地环境信息
node版本:
nodejs : v18.20.4
npm : 10.7.0
vue版本
"dependencies": {
"vue": "^3.2.13",
...
}
安装swiper依赖
执行命令:
npm i swiper
安装后,查看工程中的package.json文件,新增了swiper依赖(默认最新版):
"dependencies": {
"swiper": "^11.1.14",
"vue": "^3.2.13",
...
}
轮播图默认效果
效果说明:
1、多张图片自动播放
2、有指示器
3、有左右导航按钮(向前、向后)
图片导入工程

代码实现
<template>
<swiper
class="swiper-container"
:slides-per-view="1"
:space-between="0"
@swiper="onSwiper"
@slideChange="onSlideChange"
:modules="modules"
:pagination="{ clickable: true }"
:autoplay="{
delay: 2000,
disableOnInteraction: false,
}"
navigation
:loop="true"
>
<swiper-slide>
<img class="item" src="@/assets/banner/0.jpg"/>
</swiper-slide>
<swiper-slide>
<img class="item" src="@/assets/banner/1.jpg"/>
</swiper-slide>
<swiper-slide>
<img class="item" src="@/assets/banner/2.jpg"/>
</swiper-slide>
<swiper-slide>
<img class="item" src="@/assets/banner/3.jpg"/>
</swiper-slide>
</swiper>
</template>
<script lang="ts" setup>
import {ref} from 'vue';
import {Swiper, SwiperSlide} from 'swiper/vue';
import {Navigation, Pagination, A11y, Autoplay} from 'swiper/modules';
import 'swiper/css';
import 'swiper/css/navigation';
import 'swiper/css/pagination';
import 'swiper/css/autoplay';
const modules = [Navigation, Pagination, A11y, Autoplay]
const swiperInstance = ref<typeof Swiper | null>(null);
const onSwiper = (swiper: typeof Swiper) => {
swiperInstance.value = swiper;
};
const onSlideChange = () => {
console.log('slide change');
};
</script>
<style scoped>
.swiper-container {
background-color: white;
}
.item {
width: 100%;
height: auto;
}
</style>
代码释义:
导入swiper组件:Swiper容器;SwiperSlide子项容器
import {Swiper, SwiperSlide} from 'swiper/vue';
导入module:因为swiper将不同功能进行组件化拆分,使其更灵活化,我们使用具体的功能,只需导入相应的module即可。
导航(左右按钮功能)、Pagination(分页指示器功能)、A11y (辅助功能模块,旨在提高网站或应用的可访问性)、Autoplay(自动播放功能)
import {Navigation, Pagination, A11y, Autoplay} from 'swiper/modules';
const modules = [Navigation, Pagination, A11y, Autoplay]
导入相关样式,按功能导入相应的css:
import 'swiper/css';
import 'swiper/css/navigation';
import 'swiper/css/pagination';
import 'swiper/css/autoplay';
template中使用Swiper、SwiperSlide组件,并配置module、属性、事件等
:slides-per-view: 这个属性设置了每个滑块(slide)的可见数量。在这里,设置为 1 表示每次只显示一个滑块。
:space-between:这个属性设置了滑块之间的间距。在这里,设置为 0 表示滑块之间没有间距。
@swiper="onSwiper":这个属性是一个事件监听器,当 Swiper 初始化完成时会触发名为 "onSwiper" 的方法。
@slideChange="onSlideChange":这个属性是另一个事件监听器,当滑块切换时会触发名为 "onSlideChange" 的方法。
:modules:这个属性指定了 Swiper 实例所使用的模块。通过这个属性,可以配置 Swiper 实例使用的各种功能模块【此处配置了导航、指示器、自动播放等】。
:pagination:这个属性配置了 Swiper 的分页指示器,设置为可点击,用户可以通过点击分页器来切换到不同的滑块。
:autoplay:这个属性配置了自动播放功能,设置了播放延迟为 2000 毫秒(2秒),并且当用户交互时不停止自动播放。
navigation:这个属性开启了 Swiper 的导航按钮,通常会显示左右箭头或其他导航元素,用于用户手动导航滑块。
:loop:这个属性设置了 Swiper 是否循环播放滑块内容,即当滑动到最后一个滑块时是否自动切换到第一个滑块。设置为 true 表示开启循环播放。
<swiper
class="swiper-container"
:slides-per-view="1"
:space-between="0"
@swiper="onSwiper"
@slideChange="onSlideChange"
:modules="modules"
:pagination="{ clickable: true }"
:autoplay="{
delay: 2000,
disableOnInteraction: false,
}"
navigation
:loop="true"
>
<swiper-slide>
<img class="item" src="@/assets/banner/0.jpg"/>
</swiper-slide>
<swiper-slide>
<img class="item" src="@/assets/banner/1.jpg"/>
</swiper-slide>
<swiper-slide>
<img class="item" src="@/assets/banner/2.jpg"/>
</swiper-slide>
<swiper-slide>
<img class="item" src="@/assets/banner/3.jpg"/>
</swiper-slide>
</swiper>
定义swiper实例,用于后续swiper操作,例如:跳转下一页、暂停自动播放等等
const swiperInstance = ref<typeof Swiper | null>(null);
事件方法定义
//初始化swiper后,为swiperInstance赋值
const onSwiper = (swiper: typeof Swiper) => {
swiperInstance.value = swiper;
};
//监听slide滑块更改事件回调
const onSlideChange = () => {
console.log('slide change');
};
实现效果

优化自动播放效果
当前自动播放不受外界影响,如果用户鼠标移入swiper,应该让swiper暂停滑动,方便用户查看当前滑块的具体信息;如果鼠标滑出swiper,应该继续自动滑动。
实现:
swiper组件监听鼠标移入、移出事件:
@mouseenter="pauseSwiper"
@mouseleave="resumeSwiper"
script中,实现对应的方法:
const pauseSwiper = () => {
if (swiperInstance.value) {
swiperInstance.value.autoplay.stop();
}
};
const resumeSwiper = () => {
if (swiperInstance.value) {
swiperInstance.value.autoplay.start();
}
};
自定义左右导航按钮
swiper自带的导航按钮,多数情况下需要根据UI设计调整其效果/样式。
此处我们模拟修改下,作用导航按钮。
script中,先实现左右切换滑块的功能:
const goPrev = ()=> {
if (swiperInstance.value) {
swiperInstance.value.slidePrev();
}
};
const goNext = () => {
if (swiperInstance.value) {
swiperInstance.value.slideNext();
}
};
swiper组件上不再配置默认的navigation属性。
导入按钮图片:

布局中新增左右按钮,并设置样式:
<div class="custom-navigation">
<img src="@/assets/img_pre.png" class="custom-swiper-button-prev" @click="goPrev">
<img src="@/assets/img_next.png" class="custom-swiper-button-next" @click="goNext">
</div>
.custom-swiper-button-prev, .custom-swiper-button-next {
position: absolute;
top: 50%;
transform: translateY(-50%);
z-index: 10;
color: #FFFFFF;
font-size: 20px;
width: 50px;
height: 50px;
}
.custom-swiper-button-next {
right: 20px;
}
.custom-swiper-button-prev {
left: 20px;
}
自定义导航按钮效果:

完整代码
<template>
<swiper
class="swiper-container"
:slides-per-view="1"
:space-between="0"
@swiper="onSwiper"
@slideChange="onSlideChange"
:modules="modules"
:pagination="{ clickable: true }"
:autoplay="{
delay: 2000,
disableOnInteraction: false,
}"
:loop="true"
@mouseenter="pauseSwiper"
@mouseleave="resumeSwiper"
>
<swiper-slide>
<img class="item" src="@/assets/banner/0.jpg"/>
</swiper-slide>
<swiper-slide>
<img class="item" src="@/assets/banner/1.jpg"/>
</swiper-slide>
<swiper-slide>
<img class="item" src="@/assets/banner/2.jpg"/>
</swiper-slide>
<swiper-slide>
<img class="item" src="@/assets/banner/3.jpg"/>
</swiper-slide>
</swiper>
<div class="custom-navigation">
<img src="@/assets/img_pre.png" class="custom-swiper-button-prev" @click="goPrev">
<img src="@/assets/img_next.png" class="custom-swiper-button-next" @click="goNext">
</div>
</template>
<script lang="ts" setup>
import {ref} from 'vue';
import {Swiper, SwiperSlide} from 'swiper/vue';
import {Navigation, Pagination, A11y, Autoplay} from 'swiper/modules';
import 'swiper/css';
import 'swiper/css/navigation';
import 'swiper/css/pagination';
import 'swiper/css/autoplay';
const modules = [Navigation, Pagination, A11y, Autoplay]
const swiperInstance = ref<typeof Swiper | null>(null);
const onSwiper = (swiper: typeof Swiper) => {
swiperInstance.value = swiper;
};
const onSlideChange = () => {
console.log('slide change');
};
const pauseSwiper = () => {
if (swiperInstance.value) {
swiperInstance.value.autoplay.stop();
}
};
const resumeSwiper = () => {
if (swiperInstance.value) {
swiperInstance.value.autoplay.start();
}
};
const goPrev = ()=> {
if (swiperInstance.value) {
swiperInstance.value.slidePrev();
}
};
const goNext = () => {
if (swiperInstance.value) {
swiperInstance.value.slideNext();
}
};
</script>
<style scoped>
.swiper-container {
background-color: white;
}
.item {
width: 100%;
height: auto;
}
.custom-swiper-button-prev, .custom-swiper-button-next {
position: absolute;
top: 50%;
transform: translateY(-50%);
z-index: 10;
color: #FFFFFF;
font-size: 20px;
width: 50px;
height: 50px;
}
.custom-swiper-button-next {
right: 20px;
}
.custom-swiper-button-prev {
left: 20px;
}
</style>
vue3 使用swiper轮播组件的更多相关文章
- 【Vue中的swiper轮播组件】
<template> <swiper :options="swiperOption" ref="mySwiper"> <!-- s ...
- 微信小程序_(组件)swiper轮播图
微信小程序swiper轮播图组件官方文档 传送门 Learn: swiper组件 一.swiper组件 indicator-dots:是否显示面板指示点[默认值false] autoplay:是否自动 ...
- 【Vue项目】尚品汇(三)Home模块+Floor模块+Swiper轮播图
写在前面 今天是7.23,这一篇内容主要完成了Home模块和部分Search模块的开发,主要是使用了swiper轮播图插件获取vuex仓库数据展示组件以及其他信息. 1 Search模块 1.1 Se ...
- 基于移动端Reactive Native轮播组件的应用与开发详解
总结下这段时间学习reactive native的一些东西,我们来认识一下,被炒得这么火的rn,究竟是个什么东西,以及如何去搭建自己的demo. reactive native是什么 由facebo ...
- 移动端Reactive Native轮播组件
移动端Reactive Native轮播组件 总结下这段时间学习reactive native的一些东西,我们来认识一下,被炒得这么火的rn,究竟是个什么东西,以及如何去搭建自己的demo. reac ...
- 使用Swiper轮播插件引起的探索
提到Swiper轮播插件,小伙伴们应该不会感到陌生.以前我主要在移动端上使用,PC端使用较少. 注:这里需要注意的是,在PC端和移动端使用Swiper是不同的 官方给的版本有三个,分别是Swiper2 ...
- vue中引用swiper轮播插件
有时候我们需要在vue中使用轮播组件,如果是在vue组件中引入第三方组件的话,最好通过npm安装,从而进行统一安装包管理. 申明:本文所使用的是vue.2x版本. 通过npm安装插件: npm ins ...
- React-Native之轮播组件looped-carousel的介绍与使用
React-Native之轮播组件looped-carousel的介绍与使用 一,关于react-native轮播组件的介绍与对比 1,react-native-swiper在动态使用网页图片,多张图 ...
- vue中引入awesomeswiper的方法以及编写轮播组件
1.先安装less-loader npm install less less-loader --save 2.再安装css-loader npm install css-loader --save 3 ...
- vue-awesome-swipe 基于vue使用的轮播组件 使用(改)
npm install vue-awesome-swiper --save //基于vue使用的轮播组件 <template> <swiper :options="swi ...
随机推荐
- 强化学习baseline论文—— rainbow算法中给出实验结果的54个atari2600游戏名称列表
alien amidar assault asterix asteroids atlantis bank_heist battle_zone beam_rider berzerk bowling bo ...
- 【技术积累】如何处理Feign的超时问题
在使用Feign进行微服务之间的通信时,由于网络延迟等原因,可能会出现请求超时的情况.为了解决这个问题,我们可以对Feign进行配置,设置超时时间. 配置Feign的超时时间 在使用Feign时,我们 ...
- Python-目标检测-将xml文件转换成.txt文件
代码说明:labels文件夹是工程下的一个文件夹,里面存放的是一些xml文件. 然后我们将这些xml文件中的内容取出来,放在路径path1的文件名下.这样也就完成了xml文件到txt文件的转化. 该代 ...
- 2023 SMU RoboCom-CAIP 选拔赛
前言 更详细题解可以参考咱学长的( 2023 SMU RoboCom-CAIP 选拔赛.zip A. 小斧头 f_k 表示满足条件的j = k 的(i,j)对的数量.如上图中第四行即为f1至f5的元素 ...
- kube-flannel.yml
--- apiVersion: policy/v1beta1 kind: PodSecurityPolicy metadata: name: psp.flannel.unprivileged anno ...
- RabbitMQ接口封装
1.引用 <dependency> <groupId>com.rabbitmq</groupId> <artifactId>amqp-client< ...
- Linux 主流图形显示系统
在 Linux 系统中,主流的图形显示系统主要有以下几种: X Window System (X11) 简介 X Window System,通常简称为 X 或 X11,是历史最悠久.最广泛使用的图形 ...
- THREE.JS中 CubeTextureLoader 使用避坑
最近在跟着教程学THREE.JS,毕竟在现在的前端开发市场上,THREE.JS太火爆了. 今天学到"纹理"这一块的时候,跟着教程敲代码,发现自己的没有正确显示,百思不得其解,打开控 ...
- 微前端实践MicroApp
微前端实践 本文主要是关于microApp的实践过程记录 本文主要内容如下: 什么是MicroApp? MicroApp的父子通讯方式以及路由介绍 如何部署相关应用? 安装 npm i @micro- ...
- 为什么Java已经不推荐使用Stack了?
为什么不推荐使用Stack Java已不推荐使用Stack,而是推荐使用更高效的ArrayDeque 为什么不推荐使用 性能低:是因为 Stack 继承自 Vector, 而 Vector 在每个方法 ...