本地环境信息

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轮播组件的更多相关文章

  1. 【Vue中的swiper轮播组件】

    <template> <swiper :options="swiperOption" ref="mySwiper"> <!-- s ...

  2. 微信小程序_(组件)swiper轮播图

    微信小程序swiper轮播图组件官方文档 传送门 Learn: swiper组件 一.swiper组件 indicator-dots:是否显示面板指示点[默认值false] autoplay:是否自动 ...

  3. 【Vue项目】尚品汇(三)Home模块+Floor模块+Swiper轮播图

    写在前面 今天是7.23,这一篇内容主要完成了Home模块和部分Search模块的开发,主要是使用了swiper轮播图插件获取vuex仓库数据展示组件以及其他信息. 1 Search模块 1.1 Se ...

  4. 基于移动端Reactive Native轮播组件的应用与开发详解

    总结下这段时间学习reactive native的一些东西,我们来认识一下,被炒得这么火的rn,究竟是个什么东西,以及如何去搭建自己的demo. reactive  native是什么 由facebo ...

  5. 移动端Reactive Native轮播组件

    移动端Reactive Native轮播组件 总结下这段时间学习reactive native的一些东西,我们来认识一下,被炒得这么火的rn,究竟是个什么东西,以及如何去搭建自己的demo. reac ...

  6. 使用Swiper轮播插件引起的探索

    提到Swiper轮播插件,小伙伴们应该不会感到陌生.以前我主要在移动端上使用,PC端使用较少. 注:这里需要注意的是,在PC端和移动端使用Swiper是不同的 官方给的版本有三个,分别是Swiper2 ...

  7. vue中引用swiper轮播插件

    有时候我们需要在vue中使用轮播组件,如果是在vue组件中引入第三方组件的话,最好通过npm安装,从而进行统一安装包管理. 申明:本文所使用的是vue.2x版本. 通过npm安装插件: npm ins ...

  8. React-Native之轮播组件looped-carousel的介绍与使用

    React-Native之轮播组件looped-carousel的介绍与使用 一,关于react-native轮播组件的介绍与对比 1,react-native-swiper在动态使用网页图片,多张图 ...

  9. vue中引入awesomeswiper的方法以及编写轮播组件

    1.先安装less-loader npm install less less-loader --save 2.再安装css-loader npm install css-loader --save 3 ...

  10. vue-awesome-swipe 基于vue使用的轮播组件 使用(改)

    npm install vue-awesome-swiper --save  //基于vue使用的轮播组件 <template> <swiper :options="swi ...

随机推荐

  1. 【转载】 CPU漏洞 —— 一步一步理解CPU芯片漏洞:Meltdown与Spectre

    原文: https://www.freebuf.com/articles/system/159811.html 参考: https://blog.csdn.net/xy010902100449/art ...

  2. 记一次失败记录: MindSpore1.3.0 GPU 源码安装 —— Ubuntu18.04系统 (最终安装结果为失败)

    官网地址: https://www.mindspore.cn/install 系统:Ubuntu18.04 硬件: i7-9700k CPU 2060super nvidia显卡 由于考虑到minds ...

  3. PIL 和 python-opencv 从内存字节码中读取图片并转为np.array格式

    把某个RGB格式的图片以字节码的形式读入到内存中,然后使用PIL 和 CV2 来进行读写,并转成np.array 格式. 代码: from PIL import Image import cv2 im ...

  4. 高校教编程是否应该将Python作为主语言

    偶读一文:https://www.cnblogs.com/qing-gee/p/12941219.html 想到了这样的一个老问题,个人搞计算机软件开发.人工智能的时间已经十余年,虽然个人能力有限但是 ...

  5. 中电信翼康济世数据中台基于Apache SeaTunnel构建数据集成平台经验分享

    作者 | 中电信翼康工程师 代来编辑 | Debra Chen 一. 引言 Apache SeaTunnel作为一个高性能.易用的数据集成框架,是快速落地数据集成平台的基石.本文将从数据中台战略背景. ...

  6. SMU Summer 2024 Contest Round 1

    SMU Summer 2024 Contest Round 1 Dice and Coin 题意 给个 n 面骰子和一枚硬币,初始投骰子,若骰子的值在 1 到 \(K-1\) 之间则反复投硬币,硬币为 ...

  7. 基于surging的产品项目-木舟开源了!

    一 . 概述 因为前段时间电脑坏了,导致代码遗失,踌躇满志马上上线的平台产品付之东流,现在熬夜在写代码希望能尽快推出企业正常使用的平台产品,而这次把代码开源,一是让大家对surging 使用有个深入的 ...

  8. CentOS ssh版本升级

    1.升级openssl yum install perl wget https://goodrain-delivery.oss-cn-hangzhou.aliyuncs.com/fuzhoushuch ...

  9. RedisTemplate常用方法

    RedisTemplate常用方法 一.Redis常用的数据类型: String Hash List Set zSet Sorted set 二.RedisTemplate 常用 API 1. Str ...

  10. 为 OpenWrt 路由器编译 minieap-sysu 项目

    学校的校园网要使用锐捷认证,于是想把认证客户端装到刷了 OpenWrt 的路由器上面.然而认证客户端 Linux 版只支持 x86 架构,我的路由器处理器却是 AArch64 架构,装不了,所以只能想 ...