基于vue3封装了一个coverflow轮播图(层叠轮播图)组件

最近公司有这个需求, 但是网上找了一圈 , 没有合适的能用在vue3里面的、且长这样的组件,
干脆自己动手写了一个;

效果如下, 可以适配多张图片 ,小于五张会是平铺展示; 大于五张按顺序轮播 , 每次切换有动画
可以适配多张图片 ,小于五张会是平铺展示

<template><div class="Swiper"><div v-if="pageData.showSwiper" class="Swiper-content"><divclass="Swiper-item"v-for="(item, index) in pageData.imageUrl":key="index"><img :src="item" alt="" /></div></div><div v-else class="lessThanFiveDiv"><imgclass="lessThanFiveImg"v-for="(item, index) in pageData.imageUrl":key="index":src="item"/></div></div>
</template><script setup>
import { ref, reactive, nextTick, defineExpose } from "vue";const pageData = reactive({allData: [],imageUrl: [],showSwiper: false,startIndex: 0,
});const classList = ref(["one", "two", "three", "four", "five"]);function getNextArray(arr) {const length = arr.length;const result = [];for (let i = 0; i < 5; i++) {result.push(arr[(pageData.startIndex + i) % length]);}pageData.startIndex = (pageData.startIndex + 1) % length;return result;
}function compareArrays(arr1, arr2) {return JSON.stringify(arr1) === JSON.stringify(arr2);
}const setData = (data) => {if (compareArrays(data, pageData.allData)) return;pageData.allData = data;pageData.startIndex = 0;pageData.showSwiper = data.length >= 5;pageData.imageUrl = pageData.showSwiper ? getNextArray(data) : data;if (pageData.showSwiper) {nextTick(() => {createSwiper({SwiperContent: ".Swiper-content",classList: classList.value,});});}
};defineExpose({setData,
});function createSwiper(options) {const swiper = {$options: options,SwiperContent: null,classList: [],__init() {this.SwiperContent = document.querySelector(this.$options.SwiperContent).children;this.classList = this.$options.classList;this.__move();},__move() {pageData.imageUrl = getNextArray(pageData.allData);[...this.SwiperContent].forEach((item, index) => {item.setAttribute("class", this.classList[index]);});},__leftMove() {this.classList.unshift(this.classList.pop());this.__move();},__timers() {setInterval(() => {this.__leftMove();}, 3000);},start() {this.__init();this.__timers();},};swiper.start();return swiper;
}
</script><style scoped>
.titelText {position: absolute;font-size: 50px;width: 100%;top: 20px;text-align: center;font-family: "YouYuan";letter-spacing: 8px;color: white;text-shadow: 0 0 0px #fff, 0 0 5px #fff, 0 0 10px #fff, 0 0 15px #00ffea,0 0 20px #00ffd5, 0 0 30px #00eeff, 0 0 40px #00ffff, 0 0 50px #00fff2;
}
.bottomm {height: 100%;width: 100%;position: absolute;bottom: 0;background-image: url("../assets/image/11.png");left: 0;right: 0;background-size: 100%;background-repeat: no-repeat;border-top: 30px solid rgba(20, 20, 20, 0.5);box-shadow: 0 0 10px rgb(255, 243, 187);
}
.Swiper {height: 96%;width: 100%;position: relative;margin: 0px auto;
}.Swiper-content {height: 100%;width: 100%;position: relative;margin: 0 auto;left: 15px;
}.Swiper-content div {position: absolute;height: 100%;width: 25%;/* margin-top: 50px; */transition: all 0.6s;
}
.Swiper-content img {height: 100%;width: 100%;
}
.one {z-index: 1;transform: scale(0.8);left: 2%;box-shadow: -3px 4px 10px 1px rgba(0, 0, 0, 0.2);
}
.two {z-index: 2;transform: scale(0.9);left: 15%;box-shadow: -3px 4px 10px 1px rgba(0, 0, 0, 0.2);
}.three {z-index: 9;transform: scale(1);left: 34%;box-shadow: -3px 4px 10px 1px rgba(0, 0, 0, 0.2);
}
.four {z-index: 2;transform: scale(0.9);left: 53%;box-shadow: 3px 4px 10px 1px rgba(0, 0, 0, 0.2);
}.five {z-index: 1;transform: scale(0.8);left: 65%;box-shadow: 3px 4px 10px 1px rgba(0, 0, 0, 0.2);
}.lessThanFiveDiv {display: flex;height: 100%;justify-content: center;
}
.lessThanFiveImg {flex: 1;margin-right: 10px;height: 100%;max-width: 20%;min-width: 20%;display: block;
}
</style>

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

COSCon'24 志愿者招募令:共创开源新生活!

亲爱的开源爱好者们&#xff0c; 第九届中国开源年会&#xff08;COSCon24&#xff09;即将在北京中关村国家自主创新示范区会议中心于2024年11月2日至3日隆重举行。今年的主题是“Open Source, Open Life&#xff5c;开源新生活”&#xff0c;旨在探索开源技术如何在各个领域推…

APP综合应用之业务场景脚本测试任务(5)--多重继承与总结

在脚本中&#xff0c;有三个子类继承自父类Test_login,那么怎么同时获得三个子类的继承呢&#xff1f; 1、多重继承 下面用Test_flowdriver的子类继承自上面的三个子类。 新建一个工作流驱动的文件testtest_run_workflowV1.py 主要是创建驱动类时&#xff0c;要把三个子类都继…

VisionPro —— CogBlobTool斑点工具详解

一 CogBlobTool 简介 CogBlobTool 一个用于斑点检测和分析的工具。可以使用该工具检查图像的区域&#xff0c;并定位由灰度值有限范围内的像素组成的特征&#xff0c;这些特征的形状通常是不可预测的。检测和分析这些特征或斑点的过程称为斑点分析。您可以使用blob分析来提供有…

【C++】——list 容器的解析与极致实现

人的一切痛苦&#xff0c;本质上都是对自己的无能的愤怒。 —— 王小波 目录 1、list 介绍 2、list的使用 2.1 list 的构造 2.2 iterator 的使用 2.3 list 的修改 2.4一些特殊接口 2.5 迭代器失效问题 3、实现list 3.1底层结构 结点类 list类 迭代器类 3.2功能接…

MYSQL-SQL-04-DCL(Data Control Language,数据控制语言)

DCL&#xff08;数据控制语言&#xff09; DCL英文全称是Data Control Language(数据控制语言)&#xff0c;用来管理数据库用户、控制数据库的访问权限。 一、管理用户 1、查询用户 在MySQL数据库管理系统中&#xff0c;mysql 是一个特殊的系统数据库名称&#xff0c;它并不…

信息安全工程师(54)网络安全审计主要产品与技术指标

前言 网络安全审计是对网络系统进行全面的安全评估和检查&#xff0c;以发现网络安全漏洞和威胁&#xff0c;并采取相应的措施进行修补和防护的重要过程。 一、网络安全审计主要产品 域智盾 简介&#xff1a;一款企业级功能强大的网络监控和审计工具&#xff0c;能够持续监控网…

ElasticSearch分片

本文内容参考了田雪松老师编著的《Elastic Stack应用宝典》 ElasticSearch作为一个搜索引擎&#xff0c;会存储海量的数据。而存储海量的数据&#xff0c;就要解决如何存储的问题&#xff0c;并且保证数据不会丢失&#xff0c;同时还需要保证数据检索的效率&#xff0c;尽可能…

【Linux】总线-设备-驱动模型

背景 前面&#xff0c;我们介绍了写驱动代码的一些常规步骤&#xff0c;并且也写了最基本的驱动代码&#xff0c;但是那些代码存在着问题&#xff0c;我们将硬件的信息都写进了驱动里了&#xff0c;如果我们在杂项设备驱动中控制led&#xff0c;那么会在硬件操作接口中包含硬件…

WPF+MVVM案例实战-设备状态LED灯变化实现

文章目录 1、项目创建2、UI界面布局1. MainWindow.xaml2、颜色转换器实现2.MainViewModel.cs 代码实现 3、运行效果4.源代码下载 1、项目创建 打开 VS2022 &#xff0c;新建项目 Wpf_Examples&#xff0c;创建各层级文件夹&#xff0c;安装 CommunityToolkit.Mvvm 和 Microsof…

STMicroelectronics 意法半导体芯片选型表

意法半导体作为全球知名的半导体厂商&#xff0c;其产品广泛应用于各个领域&#xff0c;从消费电子到工业控制&#xff0c;从汽车电子到通信设备&#xff0c;都能看到意法半导体芯片的身影。在电子硬件设计领域&#xff0c;芯片的选型至关重要。亿配芯城&#xff08;ICgoodFind…

(3) c++基本代码

main函数 main函数只有可执行程序才需要&#xff0c;如果是动态库等则无需main函数。 main函数标准的写法是 #include <iostream> using namspace std; int main(void) {// 业务代码return 0; } 当然以上代码只是最简单的案例&#xff0c;其中代表main函数值是int&#…

网络编程(21)——通过beast库快速实现http服务器

目录 二十一、day21 1. 头文件和作用域重命名 2. reponse时调用的一些函数 3. http_connection a. 构造函数 b. start() c. process_request() d. create_response() e. create_post_response() f. write_response() 4. Server 5. 主函数 6. 测试 1&#xff09;测…

参加了十多个面试,一个offer也没拿到...为什么?

前几天&#xff0c;一个小伙伴留言说&#xff1a;自己面试了10多家企业了&#xff0c;愣是没有拿到一个offer&#xff0c;究竟是哪里出了问题&#xff1f; 这两天笔者抽空整理好了答案&#xff0c;借这位同学的问题&#xff0c;给大家做一个简单的剖析&#xff1a;为什么参加了…

【Blender】 学习笔记(一)

文章目录 参考概念原点 Origin游标 轴心点坐标操作默认快捷键两个比较好用的功能渲染器元素不可选&#xff08;防止误选&#xff09; 参考 参考b站视频&#xff1a;【Kurt】Blender零基础入门教程 | Blender中文区新手必刷教程(已完结) 概念 模型、灯光、摄像机 原点 Origin…

ArcGIS无插件加载(无偏移)在线天地图高清影像与街道地图指南

在地理信息系统&#xff08;GIS&#xff09;的应用中&#xff0c;加载高清影像与街道地图对于地图制图、影像查阅、空间数据分析等工作至关重要。天地图作为官方出品的地图服务&#xff0c;以其标准的数据、较快的影像更新速度等特点受到广泛欢迎。以下是如何在ArcGIS中无插件加…

《计算机视觉》—— 基于 dlib 库的方法将两张人脸图片进行换脸

声明&#xff1a;此篇文章所用的明星照片只为用于演示代码的效果&#xff0c;无诋毁她人肖像之意 一、案例实现的思想 此案例的核心是基于人脸68个关键点检测模型来实现的&#xff0c;人脸68个关键带点检测后的效果如下&#xff1a; 通过对上图中红色区域的转换&#xff0c;…

Android 图片相识度比较(pHash)

概述 在 Android 中&#xff0c;要比对两张 Bitmap 图片的相似度&#xff0c;常见的方法有基于像素差异、直方图比较、或者使用一些更高级的算法如 SSIM&#xff08;结构相似性&#xff09;和感知哈希&#xff08;pHash&#xff09;。 1. 基于像素的差异比较 可以逐像素比较…

SQL实战测试

SQL实战测试 &#xff08;请写下 SQL 查询语句&#xff0c;不需要展示结果&#xff09; 表 a DateSalesCustomerRevenue2019/1/1张三A102019/1/5张三A18 1. **用一条 ** SQL 语句写出每个月&#xff0c;每个销售有多少个客户收入多少 输出结果表头为“月”&#xff0c;“销…

【LeetCode:910. 最小差值 II + 模拟 + 思维】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…

iOS 本地存储地址(位置)

使用UserDefaults存储,数据的位置在沙盒的 Library文件下的 Preferences 里 //获取沙盒地址print("sanbox地址:",NSHomeDirectory())UserDefaults.standard.setValue("4", forKey: "tag4") 存储位置: 打开这个文件: 注意,存入到plist 文件的类型…