uniapp实现左滑显示、右滑隐藏

2023-11-01 23:50

本文主要是介绍uniapp实现左滑显示、右滑隐藏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需求

最近开发一个聊天软件,需要用到左滑显示、右滑隐藏。如图:

在这里插入图片描述

本来打算自己写,但是又因为刚接触uniapp没有思路。所以我选择在网上参考一下大家的学习学习。
偶然翻到这篇文章后觉得写的简单易懂,所以就参考学习了这篇文章:
参考文章:uniapp上实现一个左滑显示删除按钮,右滑删除按钮消失

问题

但是也遇到了问题,因为列表是for循环出来的,所以在拖动一个项目的时候都会被拖动,于是就在原代码的基础上进行了修改:

html部分
<view class="list" v-for="(item,index) in list"><view class="side-bar"><!-- 拖动后显示的功能按钮 --></view><!-- 需要拖动的模块 --><view class="mask" @touchstart="touchS" @touchmove="touchM" @touchend="touchE" @click="clickList":data-index="index" :style="{left: item.leftStyle + 'rpx'}"><view class="mask-img"><image :src="'../../static/img/' + item.img" mode="widthFix"></image></view><view class="mask-con"><view class="mask-top"><view class="mask-title">{{ item.name }}</view><image class="mask-mdr" v-show="item.mdr" src="../../static/img/mdr.png" mode="widthFix"></image><view class="mask-date">{{ item.date }}</view></view><view class="mask-bottom"><view class="mask-text">{{ item.text }}</view><view class="mask-num">{{ item.num }}</view></view></view></view><view class="hr"></view>
</view>

:data-index=“index” 不能省略,因为后面会用到!

js部分
<script>export default {data() {return {delBtnWidth: 332,//拖动后显示部分的宽度list: [{img: '',name: '',mdr: false,date: '2021/12/01',text: '',num: 99,leftStyle: 0,//移动的距离hiddenFlag: true,//左右移状态startX: 0,},{img: '',name: '',mdr: true,date: '',text: '',num: 9,leftStyle: 0,hiddenFlag: true,startX: 0,}]}},onLoad() {},onShow() {},methods: {// 遍历数组,清空列表的左移效果(其实这一块的效果不太满意,但是还是没想到最好的方式)endActive() {this.list.forEach((item, i) => {item.leftStyle = 0;})},//  点击列表之后清空左移效果clickList() {this.endActive()},// 开始移动时touchS(e) {const i = e.currentTarget.dataset.index;// 获取到当前移动元素的索引值// startX记录开始移动的位置if (e.touches.length === 1) {this.list[i].startX = e.touches[0].clientX;}// hiddenFlag为true则是从右向左,为false则是从左向右if (this.list[i].leftStyle === 0) {this.list[i].hiddenFlag = true;} else {this.list[i].hiddenFlag = false;}},touchM(e) {this.endActive()  // 开始移动后先清空左移效果再进行移动if (e.touches.length === 1) {//手指移动时水平方向位置const moveX = e.touches[0].clientX;const i = e.currentTarget.dataset.index;this.moveFunc(moveX, i);}},touchE(e) {const i = e.currentTarget.dataset.index;const { delBtnWidth } = this;// 如果停止滑动的距离大于二分之一则直接弹出删除按钮,不然则left为0if (-this.list[i].leftStyle > delBtnWidth / 2) {this.list[i].leftStyle = -delBtnWidth;} else {this.list[i].leftStyle = 0;}},moveFunc(moveX, i) {// 原始位置向左,leftStyle为小于0;原始位置向右,leftStyle为大于0// disX为相对最初位置的左右距离// 大于0为向右,小于0为向左const disX = moveX - this.list[i].startX;const delBtnWidth = this.delBtnWidth;let offsetNum = 0;if (-disX >= delBtnWidth && this.list[i].leftStyle === -delBtnWidth) {return;}// console.log(disX, this.hiddenFlag);// this.hiddenFlag为true则是从左到右,则应该将container向左移动// this.hiddenFlag为false则是从右向左,则应该将container向右移动if (this.list[i].hiddenFlag) {// 此时container为最右边,则应该将container向左移动// disX大于0为相对原始位置的向右移动,则直接将offsetNum置为0// 否则为向左移动,offsetNum为disX相反的值,判断是否超过设置的最大位置if (disX == 0 || disX > 0) {offsetNum = 0;} else {offsetNum = disX;if (disX <= -delBtnWidth) {//控制手指移动距离最大值为删除按钮的宽度offsetNum = -delBtnWidth;}}} else {// 此时container为最左边,应该向右移动// disX小于0为相对原始位置的向左移动,则直接将offsetNum置为-this.delBtnWidth// 否则为相对原始位置的向右移动,此时应该将最大位置与向右位置的差值为此刻位置,判断是否为大于0if (disX < 0) {offsetNum = -this.delBtnWidth;} else {offsetNum = -this.delBtnWidth + disX;if (offsetNum > 0) {offsetNum = 0;}}}this.list[i].leftStyle = offsetNum;}}}
</script>

原博主是将leftStyle: 0,startX: 0,hiddenFlag: true设置到了数组外,我是将每个数组都添加了这三个。

修改

touchS({ touches }) 修改成 ——> touchS(e)
if(touches.length === 1) { 修改成 ——> if (e.touches.length === 1) {

{touches}换成e是为了获取到当前移动元素的索引值:

const i = e.currentTarget.dataset.index;

获取到索引值后对数组内改项目对应字段进行修改,用下面两个片段举个栗子:
开始移动时:

touchS(e) {const i = e.currentTarget.dataset.index;// startX记录开始移动的位置if (e.touches.length === 1) {this.list[i].startX = e.touches[0].clientX;}// hiddenFlag为true则是从右向左,为false则是从左向右if (this.list[i].leftStyle === 0) {this.list[i].hiddenFlag = true;} else {this.list[i].hiddenFlag = false;}
},

移动时将索引值传入moveFunc()方法

touchM(e) {this.endActive()if (e.touches.length === 1) {//手指移动时水平方向位置const moveX = e.touches[0].clientX;const i = e.currentTarget.dataset.index;this.moveFunc(moveX, i);}
},

文中有链接我参考的原文,写的很好也很详细,也可以留言和我沟通。第一次写文章有写的不好的地方也可以和我指出~

这篇关于uniapp实现左滑显示、右滑隐藏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、