第三十七篇 Vue中封装Swiper组件

news2025/7/19 4:51:51

         在上一篇内容的结尾讲到了将swiper初始化从mounted生命周期转移到updated中来能够让swiper动起来,但同时是否会造其他的一个问题?什么问题呢?在每次data中的状态发什么改变,updated中的内容会又重新执行,这样会导致swiper的初始化会重复的执行,如果封装成组件显然不合适,那么如何改进并将swiper封装成一个组件,封装为一个可复用性的组件;那么下面就来如何从静态的swiper组件再到一个动态可被复用的软件;

1.  静态的 swiper 组件

<div id="app">
    <swiper></swiper>
</div>
Vue.component("swiper",{
    template:`
        <div>
            <div class="swiper-container author" >
                <div class="swiper-wrapper">
                    <div class="swiper-slide">slider1</div>
                    <div class="swiper-slide">slider2</div>
                    <div class="swiper-slide">slider3</div>
                </div>
            <div class="swiper-pagination"></div>
            </div>
        </div>
    `
})

        那么同样的,在组件内部如何来设置 swiper 的初始化,先来mounted生命周期中进行swiper的初始化;

mounted(){
    new Swiper(".author",{
        loop:true,
        autoplay:{
            delay:2000
        },
        pagination:{
            el:'.swiper-pagination'
        }
    })
}

测试效果:

        结果与先前在页面当中静态使用swiper一致,并没有太多需要注意的问题,现在将数据换成图片进行轮播,在template模板上就需要添加一个<img>容器放置图片:

template:`
    <div>
        <div class="swiper-container author" >
            <div class="swiper-wrapper">
                <div class="swiper-slide">
                    <img src="" />    
                </div>
                <div class="swiper-slide">
                    <img src="" />        
                </div>
                <div class="swiper-slide">
                    <img src="" />    
                </div>
            </div>
        <div class="swiper-pagination"></div>
        </div>
    </div>
`,

        测试效果符合预期,静态的使用swiper并没有什么问题; 

        显然静态的这样一个组件根本就不能够达到想要进行复用,因为对应的轮播数据已经被固定写死了,在实际当中我们是通过异步请求数据然后将数据给到swiper组件;

2. 动态的 swiper 组件

        既然静态的封装swiper组件不具备可复用性和灵活性,那么下面来改造一下;既然不能够将轮播的数据固定,那么把轮播的内容提取出来,通过插槽的形式;将请求回来的数据通过v-for的指令进行渲染;

        在mounted生命周期中发起数据请求,然后赋值给swiperList,最后进行swiper的初始化,那么看过上一篇内容就知道swiper动态的使用会有这样的一个问题就是swiper的初始化过早,会选择在updated当中去初始化才能够让swiper滚动起来,那么同样来测试一下:

<div id="app">
    <swiper>
        <div class="swiper-slide" v-for="(item,index) in swiperList" :key="index"> 
            <img :src="item" />    
        </div>
    </swiper>
</div>
<script>

// swiper组件
Vue.component("swiper",{
    template:`
        <div>
            <div class="swiper-container author" >
                <div class="swiper-wrapper">
                    <slot></slot>
                </div>
            <div class="swiper-pagination"></div>
            </div>
        </div>
    `
})

new Vue({
    el:'#app',
    data:{
        swiperList:[]  // 请求的数据容器
    },
    mounted(){
        // 模拟发起ajax请求
        setTimeout(()=>{
            // 假设请求回来的数据赋值给swiperList
            this.swiperList = [ 
                'http://图片链接1' ,
                'http://图片链接2' ,
                'http://图片链接3' ]; 
        },2000)
    },

    updated(){
        // swiper初始化
        new Swiper(".author",{
            loop:true,
            pagination:{
                el:'.swiper-pagination'
            }
        })    
    }
})
</script>

测试效果:能够实现轮播,也有对应的指示器,这样我们是不是就成功了呢?

        显然不是,在上一篇内容结尾和本篇开头就讲过了在updated生命周期当中来初始化能够解决swiper组件能够动起来的燃眉之急,但问题也随之接踵而来,当data数据状态改变,updated会重复的初始化swiper,那么既然要让swiper只执行初始化一次又能够让swiper组件动起来,那么不能够在updated生命周期中,只能是从mounted生命周期中进行swiper的初始化;

key值

        还记得key值吗?在前面的内容当中我们已经多次的提及到了设置key值的内容,在 Vue 当中对于DOM的更新是先通过虚拟DOM进行diff之后再进行patch最后才会在页面中更新真实DOM,那么在进行虚拟DOM的对比,讲过使用index索引值和key值的对比方式,在mounted生命周期当中出现的问题就是初始化过早,那么在未收到数据之前swiper已经创建完成了,当收到数据的时候会进行新旧数据的对比,这一对比会发现swiper组件并没有任何变化,仅仅是内部数据发生变化,Vue为了提高这个用户体验提高效率将这个新数据替换到旧数据当中去;

|| 通过上面的描述来进行一次编写测试效果,然后再来进一步的了解整个过程:

1. 编写代码:

<div id="app">
    <swiper :key="swiperList.length">
        <div class="swiper-slide" v-for="(item,index) in swiperList" :key="index"> 
            <img :src="item" />    
        </div>
    </swiper>
</div>
<script>
Vue.component("swiper",{
    template:`
        <div>
            <div class="swiper-container author" >
                <div class="swiper-wrapper">
                    <slot></slot>
                </div>
            <div class="swiper-pagination"></div>
            </div>
        </div>    
    `,
    mounted(){
        new Swiper(".author",{
            loop:true,
            autoplay:{
                delay:2000
            },
            pagination:{
                el:'.swiper-pagination'
            }
        })
    }
})

new Vue({
    el:'#app',
    data:{
        swiperList:[]  // 请求的数据容器
    },
    mounted(){
        // 模拟发起ajax请求
        setTimeout(()=>{
            this.swiperList = [ 
                'https://s2.loli.net/2022/07/18/1nMDLzF35hsYZ8t.jpg' ,
                'https://s2.loli.net/2022/07/18/yFXUisGht9x5PjY.jpg' ,
                'https://s2.loli.net/2022/07/18/8WhpU5EDQTySONY.jpg' ]; 
        },2000)
        console.log("mounted");
    }
})
</script>

2. 测试效果:

         swiper组件能够正常的轮播起来,这样是一来避免之前在updated生命周期当中做swiper的初始化从而导致data数据状态一改变而引起在updated中swiper的一个重复初始化工作;


 下面用图示来进一步讲解:

         通过设置key的形式让前后虚拟DOM的对比使得swiper在swiperList有数据的情况下能够进行初始化,以此才能够让swiper动起来;

        在下面这里来进行一个验证,是否进行 mounted —— destoryed (key=0)—— mounted(key=3):

<script>
Vue.component("swiper",{
    ...
    mounted(){
        new Swiper(".author",{
            loop:true,
            autoplay:{
                delay:2000
            },
            pagination:{
                el:'.swiper-pagination'
            }
        })
        console.log("mounted");
    },
    destoryed(){
        console.log("destoryed");
    }
})

new Vue({
    el:'#app',
    data:{
        swiperList:[]  // 请求的数据容器
    },
    mounted(){
        // 模拟发起ajax请求
        setTimeout(()=>{
            ...
        },2000)
        console.log("mounted");
    }
})
</script>

 测试效果:

        通过设置key的方式能够解决在mounted中初始化过早和在updated中会因data数据状态的改变而频繁初始化swiper的问题;那么swiper组件的封装就到此结束了吗?当然没有,为了使篇幅不过长和内容的渐进性,在下一篇内容当中继续本篇在Vue中封装swiper组件的话题!感谢大家一直以来的支持和粉丝朋友们!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/36259.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

二维数组与二级指针是好朋友吗?

抛出问题 有一个二维数组&#xff0c;我想把它传给一个函数。于是我把函数接口定义出来了&#xff0c;如下&#xff1a; int array[2][3] {1,2,3,4,5,6}; void fun(int **array) {array[0][0] 5; } 当我试图直接把数组名传给函数时候&#xff0c;fun(array)编译会报错&…

C++ 中explicit的作用及用法

目录 Cexplicit&#xff08;官网的说法&#xff09; Cexplicit 清楚的说法&#xff08;建议英文不好的从这里开始食用哦&#xff09; Cexplicit使用的例子&#xff08;建议喜欢自己敲代码实验的从这里开始食用哦&#xff09; 总结 Cexplicit&#xff08;官网的说法&#xff…

神经网络和深度学习-梯度下降Gradient Descent(下)

梯度下降gradient descent 我们接着用数学公式来看一下梯度下降 首先是梯度 ∂cos⁡t∂ω\frac{\partial \cos t}{\partial \omega} ∂ω∂cost​ 然后我们对权重进行更新 ωω−α∂cos⁡t∂ω\omega\omega-\alpha \frac{\partial \cos t}{\partial \omega} ωω−α∂ω∂c…

python基础之容器类型公共方法

文章目录一、简介1.高级数据类型的公共方法&#xff1a;2.python的内置函数&#xff1a;3.python包含的内置函数&#xff1a;二、遍历字典的列表一、简介 1.高级数据类型的公共方法&#xff1a; 列表元组字典或者字符串都能够共同使用的方法&#xff1b; 2.python的内置函数…

【kafka】七、kafka数据可靠性保证

数据可靠性保证 为保证producer发送的数据&#xff0c;能可靠的发送到指定的topic&#xff0c;topic的每个partition收到producer发送的数据后&#xff0c;都需要向producer发送ack&#xff08;acknowledgement确认收到&#xff09;&#xff0c;如果producer收到ack&#xff0c…

基于AntBlazor的学生在线练习系统实现过程的简单总结

前言 疫情当前&#xff0c;作为一名教师&#xff0c;如何能让学生进行有效练习成了一个难题。如果使用 “问卷星”等线上调查问卷式的网站来做练习测试&#xff0c;是无法及时有效的进行&#xff0c;更谈不上对学生练习情况进行跟踪。鉴于以上现实情况和问题&#xff…

神经网络和深度学习-用pytorch实现线性回归

用pytorch实现线性回归 用pytorch的工具包来实现线性模型的训练过程 准备数据集 设计模型 构造损失函数和优化器&#xff08;使用pytorch API&#xff09; 训练过程&#xff1a;前馈、反馈、更新 准备数据 在PyTorch中&#xff0c;计算图是小批处理的&#xff0c;所以X和…

MATLAB | 世界杯来用MATLAB画个足球玩叭~

世界杯教你用MATLAB画个超逼真的足球&#xff0c; 需要准备Partial Differential Equation Toolbox工具箱&#xff0c;同时因为用到了polyshape类所以至少需要R2017b版本。 绘制讲解 数据来源及说明 我是真的不想写注释了太麻烦了&#xff0c;给大家讲一下我的思路希望能够看…

判断一个时间段是否经过了另一个时间段

场景&#xff1a; IOT设备存在离线与恢复时间记录&#xff0c;每一次离线和恢复记为一个周期即一条数据, 现在需要统计出在某个时段存在离线记录的数据,如果目前未恢复,没有恢复时间&#xff0c;恢复时间置为9999-01-01 00:00:00 原始数据如下(t_offline_record)&#xff1a;…

OPengl学习——初识opengl

文章目录1、网站罗列2、一些词语解析1.入门概念2.Opengl Vs DirectX3、QOpenGLWidget4、引用**OpenGL&#xff08;Open Graphics Library&#xff09;*是一个跨编程语言、跨平台的编程图形程序接口&#xff0c;它将计算机的资源抽象称为一个个OpenGL的对象&#xff0c;对这些资…

3.5、点对点协议 PPP

3.5、点对点协议 PPP 3.5.1、基本介绍 点对点协议 PPP(Point-to-Point Protocol) 是目前使用最广泛的点对点数据链路层协议。 用户计算机只有获取到 ISP 所分配的合法 IP 地址后&#xff0c;才能成为因特网上的主机 用户计算机与 ISP 进行通信时&#xff0c;所使用的数据链路…

【学习笔记21】JavaScript数组的基本方法

笔记首发 一、push&#xff1a;末位新增 语法: 数组.push(数据)作用: 向数组末尾添加数据返回值: 追加数据后, 数组最新的长度 var arr [10, 20, 30, 40];console.log(原始数组: , arr); ​var num arr.push(500);console.log(push新增后数组: , arr);console.log(push的返回…

进程的初识

目录预备知识 -> 操作系统操作系统的定义操作系统的定位进程进程的概念进程调度的过程进程的管理描述组织PCB描述进程的特征进程调度的相关属性进程的状态优先级上下文记账信息预备知识 -> 操作系统 操作系统的定义 操作系统是一个搞管理的软件 对上&#xff0c;要对硬…

为什么一定要申请专利呢

问题一&#xff1a;如何避免被判为非正常专利&#xff1f; 原本有个发明创造&#xff0c;想申请专利&#xff0c;却被列入非正常申请&#xff0c;甚至违法。以下五种情况一定要注意&#xff0c;千万不能碰。 1、同一单位或个人申请多件明显抄袭现有技术的专利&#xff1b; 2…

如何通过 Java 合并和取消合并 Excel 单元格

在整理 Excel 中的数据时&#xff0c;我们不可避免地需要合并和取消合并单元格。同时&#xff0c;如果需要创建跨列或行的标题&#xff0c;我们可以合并 Excel 单元格以在电子表格中轻松完成此操作。 合并单元格是指将两个或多个单元格合并为一个单元格&#xff0c;而取消合并单…

4.4——数据库和前后端身份认证

目录数据库与身份认证数据库的基本概念什么是数据库常见的数据库及分类传统型数据库的数据组织结构安装并配置 MySQL使用 MySQL Workbench 管理数据库连接数据库了解主界面的组成部分创建数据库创建数据表向表中写入数据使用 SQL 管理数据库在项目中操作 MySQL安装与配置 mysql…

华为机试 - 数大雁

目录 题目描述 输入描述 输出描述 用例 题目解析 算法源码 题目描述 一群大雁往南飞&#xff0c;给定一个字符串记录地面上的游客听到的大雁叫声&#xff0c;请给出叫声最少由几只大雁发出。 具体的: 1.大雁发出的完整叫声为”quack“&#xff0c;因为有多只大雁同一时…

怎么还不会进制转换,进来学。

✨进制转换&#xff0c;深度讲解✨特殊的十进制转换&#xff08;整数&#xff09;一、十进制转换为其他进制二、其他进制转换为十进制二进制的特殊转换&#xff08;整数&#xff09;一、二进制转换为其他进制二、其他进制转换为二进制任意进制的转换&#xff08;整数&#xff0…

Java项目:JSP高校新生报到迎新管理系统

作者主页&#xff1a;源码空间站2022 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 辅导员角色包含以下功能&#xff1a; 辅导员登录,学生留言管理,新生报到管理,宿舍分配管理等功能。 财务管理角色包含以下功能&#xff1a; 财务…

一道Android题目逆向动态调试

题目来源于海淀区网络与信息安全管理员大赛&#xff0c;题目中将加密验证算法打包进.so&#xff0c;在程序中动态调用check。 本题目通过System.loadLibrary(“native-lib”)加载了libnative-lib.so文件&#xff0c;该文件通过jeb可以实现提取 图1 题目关键代码 调试环境选择…