VUE——Swiper滑动特效插件【主要就是做轮播图】

Swiper(官网:https://www.swiper.com.cn/)
是纯javascript打造的滑动特效插件,面向手机、平板电脑等移动终端。
能实现触屏焦点图、触屏Tab切换、触屏多图切换等常用效果。
开源、免费、稳定、使用简单、功能强大,是架构移动终端网站的重要选择,
也支持PC端,在这里我们使用稳定的3.4.2版本。
使用Swiper有两种方式:


1.CDN引入:
//引入压缩版CSS样式
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/Swiper/3.4.2/css/swiper.min.css">
//引入压缩版swiper.js
<script src="https://cdnjs.cloudflare.com/ajax/libs/Swiper/3.4.2/js/swiper.min.js"></script>
2.模块化
下载Swiper,由于Swiper支持commonJS规范,所以可以用import导入,支持模块化。

第一步:从Swiper(官网:https://www.swiper.com.cn/) 下载Swiper.3.4.2压缩包

第二步:单独建一个文件夹,把Swiper.3.4.2压缩包中的 wiper.js和swiper.css文件放入其中。

在这里插入图片描述

第三步:使用import模块化导入组件

将swiper.css导入< style>< /style>里
将swiper.js 导入< script></ script>里
在这里插入图片描述

第四步:在Swiper文档中查看Swiper初始化

<div class="swiper-container">
  <div class="swiper-wrapper">
    <div class="swiper-slide">slider1</div>
    <div class="swiper-slide">slider2</div>
    <div class="swiper-slide">slider3</div>
  </div>
</div>
<script> 
var mySwiper = new Swiper('.swiper-container', {
	autoplay: 5000,//可选选项,自动滑动
})
</script>

Swiper建议我们使用ref来获取元素
在这里插入图片描述

在这里插入图片描述

<template>
  <div>
    <div class="banner-wrap">
      <div class="swiper-container" ref="swiper-container">
        <div class="swiper-wrapper">
          <div class="swiper-slide" v-for="(item,index) in imglist " :key="index"><img :src=" item.image" /></div>
        </div>
        <div class="swiper-pagination" ref="swiper-pagination"></div>
      </div>
    </div>
  </div>
</template>

<script>
//import { nextTick } from "vue/types/umd";
//import { nextTick } from "vue/types/umd"
import Swiper from"../../assets/js/libs/swiper/swiper"
import{ requestfirst} from"../../assets/js/utils/request"
export default{
    name:"name-swiper",
    data(){
        return{
            imglist:[]
        }
    },
        created(){

                requestfirst(this.$config.baseApi+"/home/index/slide?token="+this.$config.token).then(res=>{
                    console.log(res);
                    if(res.code==200){
                        this.imglist=res.data;
                           
                            this.$nextTick( ()=>{
                                new Swiper(this.$refs['swiper-container'],{
                                autoplay: 3000,
                                pagination : this.$refs['swiper-pagination'],
                                paginationClickable :true,
                                autoplayDisableOnInteraction : false,
                                })

                            })



                    }

                })


        },



    // mounted(){

    //   new Swiper(this.$refs['swiper-container'],
    //   {  autoplay: 3000,
    //      pagination : this.$refs['swiper-pagination'],
    //      paginationClickable :true,
    //      autoplayDisableOnInteraction : false,
    //     })
    // }



}
</script>
<style>
@import"../../assets/js/libs/swiper/swiper.css";
.banner-wrap{width: 100%;height: 200PX;}
.swiper-container{width: 100%;height: 100%;}
img{width: 100%;height:100%;}
</style>

created中的数据请求:

在created中,调用了requestfirst来获取轮播图的数据。这个请求是异步的,意味着它不会阻塞后续代码的执行,而是会在请求完成后执行回调函数。

mounted中的Swiper初始化:

在mounted中,直接初始化了Swiper。但是,由于数据请求是异步的,mounted可能在数据请求完成之前就已经执行了。这意味着Swiper可能会在imglist为空的情况下初始化,导致轮播图无法正确显示。

this.$ nextTick的使用:

在created中的数据请求成功后,使用了this.$ nextTick来包裹Swiper的初始化代码。$nextTick的作用是等待DOM更新后再执行内部的代码。这样可以确保在数据更新后,DOM已经渲染完毕,Swiper可以正确地初始化

异步操作的影响:

在created中调用异步请求,比如requestfirst,这个请求不会阻塞created的执行,created会继续执行后续的代码。如果mounted在created之后执行,那么mounted可能会在数据请求完成之前执行,导致Swiper初始化时数据还没有准备好。

this.$nextTick的作用:

this.$ nextTick的作用是确保在DOM更新完成后执行内部的代码。在数据请求成功后,imglist被赋值,Vue会触发DOM更新。使用$nextTick可以确保在DOM更新完成后初始化Swiper,这样Swiper可以正确地找到所有的swiper-slide元素。

为什么在created中使用$nextTick来初始化Swiper,而不是直接在mounted中初始化?

因为mounted可能在数据请求完成之前执行,导致Swiper初始化时数据还没有准备好。使用$nextTick在数据请求成功后初始化,可以确保数据已经加载完成,DOM已经更新。

在created中使用$nextTick来初始化Swiper,确保在数据加载完成且DOM更新完成后进行初始化,避免Swiper初始化时数据未准备好。直接在mounted中初始化Swiper可能会导致Swiper在数据未加载完成的情况下执行,影响轮播图的显示效果。

关键时间节点:

created阶段:数据观测已初始化,但尚未生成真实DOM。

mounted阶段:真实DOM已挂载,但此时可能没有数据(请求未完成)。

危险操作:若在mounted直接初始化Swiper,可能遇到空DOM结构。

数据观测已初始化:

1. 什么是数据观测(Reactivity)
数据观测是Vue的 响应式系统核心。当你在data()中定义数据时,Vue会将其转换为响应式对象。例如:

// 你写的data选项
data() {
  return { count: 0 }
}

const observedData = {
  _value: 0, // 实际存储值的内部属性
  // 定义 count 属性的 getter/setter
  get count() {
    track(this, 'count') // 1️⃣ 依赖收集:记录当前正在读取 count 的代码
    return this._value
  },
  set count(newVal) {
    this._value = newVal
    trigger(this, 'count') // 2️⃣ 触发更新:通知所有依赖 count 的代码更新
  }
}

3. track() 的作用
当任何代码 读取 count 时,track() 会记录这个读取操作(收集依赖)。例如:
模板中的使用:{{ count }}
组件的计算属性:double() { return this.count * 2 }
当这些代码运行时,读取 count 会触发 track()

4. trigger() 的作用
当任何代码 修改 count 时,trigger() 会通知所有依赖 count 的地方更新。例如:
点击按钮修改 count
this.count = 1
此时会触发所有依赖 count 的模板、计算属性、watch 等更新

5. this 的指向
在 getter/setter 中,this:当前数据对象(如 observedData 的实例)

在这里插入图片描述

2. created阶段具体发生了什么
在created生命周期阶段:

  1. 已完成:props/methods/data的初始化
  2. 已完成:数据观测(即建立getter/setter)
  3. 未完成:模板编译、虚拟DOM生成、真实DOM挂载
### 使用 `vue-awesome-swiper` 插件Vue 3 中创建轮播图 为了在 Vue 3 中使用 `vue-awesome-swiper` 创建轮播图,需先安装必要的依赖项。由于 `vue-awesome-swiper` 主要基于 Swiper 库构建,因此也需要安装 Swiper。 #### 安装依赖包 通过 npm 或 yarn 来安装所需的库: ```bash npm install vue-awesome-swiper swiper --save ``` 或者如果偏好使用 yarn: ```bash yarn add vue-awesome-swiper swiper ``` #### 配置项目以支持 ES Modules 和 Composition API 考虑到 Vue 3 的特性以及对 Composition API 的支持,在 main.js 文件中引入并注册全局组件之前,应该确保按照官方文档配置好环境[^1]。 #### 编写轮播图组件代码 下面是一个简单的轮播图实现例子,适用于 Vue 3 及其组合式API风格: ```javascript // src/components/Carousel.vue <template> <div class="swiper-container"> <!-- Additional required wrapper --> <div class="swiper-wrapper"> <div v-for="(slide, index) in slides" :key="index" class="swiper-slide">{{ slide }}</div> </div> <!-- If we need pagination --> <div class="swiper-pagination"></div> <!-- If we need navigation buttons --> <div class="swiper-button-prev"></div> <div class="swiper-button-next"></div> </div> </template> <script setup> import { ref } from 'vue'; import 'swiper/css/swiper.css'; const props = defineProps({ slides: { type: Array, default() { return ['Slide 1', 'Slide 2', 'Slide 3']; } }, }); let mySwiper; onMounted(() => { import('vue-awesome-swiper').then(({ Swiper }) => { mySwiper = new Swiper('.swiper-container', { loop: true, // 如果需要分页器 pagination: { el: '.swiper-pagination', }, // 如果需要前进后退按钮 navigation: { nextEl: '.swiper-button-next', prevEl: '.swiper-button-prev', }, }); }); }); </script> <style scoped> /* Add custom styles here */ .swiper-slide { text-align: center; font-size: 18px; background-color: #fff; } </style> ``` 此示例展示了如何利用 `vue-awesome-swiper` 结合 Vue 3 构建一个基本的轮播图,并包含了分页指示符和导航箭头的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值