H5仿探探左右滑动效果Vue.js

2023-10-22 17:10
文章标签 vue js 效果 滑动 h5 左右 探探

本文主要是介绍H5仿探探左右滑动效果Vue.js,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 效果图:

 

效果图:GIF

 

说明 H5仿探探左右滑动效果

<template><div class="slide"><divclass="slide_item"v-for="(item,index) in listArr":key="index":style="[initCSS(index),Transform(index)]"@touchstart.stop.prevent.capture="touchStart($event,index)"@touchmove.stop.prevent.capture="touchMove($event,index)"@touchend.stop.prevent.capture="touchEnd(index)"v-show="item.show"><span class="title">第{{item.index + 1}}个</span><span class="text">仿探探左右滑动效果/初始化50个</span><span class="text">只支持移动端</span></div></div>
</template>
<script>
export default {name: "slide",data() {return {listArr: [],/*记录x y轴*/x: {start: 0,move: 0,end: 0},y: {start: 0,move: 0,end: 0},/*下标*/currentIndex: 0,/*宽度宽度*/winWidth: 0,/*xy位移*/displacement: {x: 0,y: 0},/*滑动*/swipering: false,/*滑动中*/slideing: false,};},mounted() {this.init();},methods: {init() {/* 测试数据*/for (let index = 0; index < 50; index++) {var data = {index: index,show: true,x: 0,y: 0,opacity: index < 3 ? 1 : 0};this.listArr.push(data);}this.winWidth = document.documentElement.clientWidth;},initCSS(index) {let css = {};css["z-index"] = index;css["transform"] = `translate3d(0,0,${(this.currentIndex - index) *50}px)`;css["transitionDuration"] =   "0ms";return css;},Transform(index) {let css = {};if (!this.swipering) {css["transitionDuration"] = "300ms";} else {css["transitionDuration"] = "0ms";}if (index === this.currentIndex) {css["transform"] = `translate3d(${this.listArr[index].x}px,${this.listArr[index].y}px,${(this.currentIndex - index) * 50}px)`;}css['opacity'] = this.listArr[index].opacity;return css;},touchStart(e) {if(this.slideing) return;this.swipering = true;this.x.start = e.touches[0].pageX;this.y.start = e.touches[0].pageY;},// 滑动计算touchMove(e, index) {if(this.slideing) return;if(this.listArr.length == index + 1){return;}this.x.move = e.touches[0].pageX;this.y.move = e.touches[0].pageY;this.displacement.x, (this.listArr[index].x = this.x.move - this.x.start);this.displacement.y, (this.listArr[index].y = this.y.move - this.y.start);},// 滑动结束判断是否超过一定值touchEnd(index) {this.swipering = false;if(this.listArr.length == index + 1){return;}if (this.listArr[index].x > 0 &&this.listArr[index].x > this.winWidth / 2 - this.winWidth / 4.5) {this.touchEndNext(index);} else if (this.listArr[index].x < 0 &&this.listArr[index].x < -this.winWidth / 2 + this.winWidth / 4.5) {this.touchEndNext(index);} else {this.listArr[index].x = 0;this.listArr[index].y = 0;this.slideing = false;}},touchEndNext(index) {this.slideing = true;this.listArr[index].x = this.listArr[index].x * 3;this.listArr[index].y = this.listArr[index].y * 3;var a = setTimeout(() => {this.$set(this.listArr[index], "show", false);this.$nextTick(() => {this.currentIndex++;if(index + 3 < this.listArr.length){this.$set(this.listArr[index + 3], "opacity", 1);}this.slideing = falsea;});}, 300);}}
};
</script>

.slide {position: relative;width: 95%;height: 500px;perspective: 1000px;perspective-origin: 50% 150%;transform-style: preserve-3d;
}
.slide .slide_item {transform-style: preserve-3d;display: flex;width: 100%;height: 100%;border-radius: 20px;position: absolute;z-index: 30;background: #fff;display: flex;justify-content: center;align-items: center;text-align: center;/* opacity: 0; *//* display: none; */text-align: center;font-size: 30px;line-height: 1;transform: translate3d(0px, 0px, 0px) rotate(0deg);box-shadow: 0 10px 15px 0 rgba(0, 0, 0, 0.15);transition: 300ms;opacity: 0;flex-direction: column;
}
.slide .slide_item .title{font-size: 50px;
}
.slide .slide_item .text{font-size: 16px;margin-top: 10px;
}

由于csdn没有vue格式代码插入所以分成三段展示

这篇关于H5仿探探左右滑动效果Vue.js的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/262625

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方