微信小程序实现单个卡片左滑显示按钮并防止上下滑动干扰功能
作者:wantingtr 发布时间:2024-04-18 10:03:54
标签:微信小程序,按钮
实现类似ios端微信的左滑显示置顶、删除按钮的功能,首先需将按钮部分设为绝对定位,并且right设为负值溢出屏幕。利用小程序事件处理的api,分别读取触摸开始,触摸移动时,触摸结束的X/Y坐标,根据差值来改变整个卡片的位置。
这里有一个细节,为了防止按钮的点击干扰到卡片主部分的滑动,需要将整个卡片分为两部分。
<View style={`${positionStyle[index]}`}>
<View
onTouchStart={this.moveTaskStart}
onTouchMove={this.moveTask}
onTouchEnd={this.moveTaskEnd}
>
这是主要的卡片部分
</View>
<View style="right: -260px;">这是滑动后出现的按钮部分</View>
</View>
这里使用的是Taro框架,方法与原生事件api一样,在开始滑动时分别存入X,Y坐标,在手指移动过程中计算移动的距离,当X的移动距离大于整个按钮部分的一班,展开按钮。
核心功能的实现,只需要分析X坐标即可,但因为用户可能在上下滑动过程中x坐标也会偏移造成按钮的展开,所以需要在move与end两部分都计算垂直坐标的改变与水平坐标改变形成的角度,当角度过大,视为上下滑动,按钮不展开。
完整代码如下:
moveTaskStart(e) {
if (e.touches.length == 1) {
//触摸屏上只有一个触摸点
this.setState({
// 开始触摸屏幕的X坐标
startX: e.touches[0].clientX,
startY: e.touches[0].clientY
});
}
}
moveTask(e) {
if (e.touches.length == 1) {
let moveX = e.touches[0].clientX;
let moveY = e.touches[0].clientY;
// 移动距离
let disX = this.state.startX - moveX;
let disY = this.state.startY - moveY;
let angle = disY > 0 ? disY / disX : -disY / disX;
let btnWidth = this.state.btnWidth;
let txtStyle = "";
if (disX == 0 || disX < 30) {
//右滑动
txtStyle = "left:0px";
} else if(angle > 0.5) {
return;
} else if (disX > 30 && angle < 0.5) {
txtStyle = `left: -${disX}px`;
if (disX >= btnWidth) {
//距离最大值
txtStyle = `left: -${btnWidth}px`;
}
}
let index = e.currentTarget.dataset.index;
let list = this.state.positionStyle;
this.setState({
positionStyle: list
});
}
}
moveTaskEnd(e) {
let txtStyle;
if (e.changedTouches.length == 1) {
let endX = e.changedTouches[0].clientX;
let moveY = e.changedTouches[0].clientY;
//移动距离
let disX = this.state.startX - endX;
let disY = this.state.startY - moveY;
//移动角度
let angle = disY > 0 ? disY / disX : -disY / disX;
let btnWidth = this.state.btnWidth;
//如果距离大于按钮宽度的一半,并且移动角度较小,显示按钮
if(disX > (btnWidth / 2) && angle < 0.5) {
txtStyle = `left:-${btnWidth}px`
}else {
txtStyle = "left:0px"
}
let index = e.currentTarget.dataset.index;
let list = this.state.positionStyle;
list[index] = txtStyle;
this.setState({
positionStyle: list
});
}
}
总结
以上所述是小编给大家介绍的微信小程序实现单个卡片左滑显示按钮并防止上下滑动干扰功能网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
来源:https://blog.csdn.net/wantingtr/article/details/98221401


猜你喜欢
- 复制目录: 包含多层子目录方法: 递归, 深度遍历,广度遍历深度遍历&广度遍历:思路:1.获得源目录子级目录,并设置目标目录的子级路
- 在python类当中,经常会遇到@classmethod和@staticmethod这两个装饰器,那么到底它们的区别和作用是啥子呢?具体来看
- random模块该模块实现了各种分布的伪随机数生成器。(包括在实数轴上计算均匀、正态(高斯)、对数正态、负指数、伽马和贝塔分布的函数)不应将
- 问题今天在写项目功能的时候,有一个统计金额的情况,然后需要进行单位转换,所以写下了大概如下功能的语句,但得到的数据为小数点后4位精度,正常我
- virtualenvwrapper是用来管理virtualenv的扩展包,用着很方便。1. 安装:#安装virtualenvwrapper$
- 在前面已经学习了gin框架如何处理请求,解析请求,返回数据。在实际的项目当中,项目往往是以模块化来进行划分和开发的,所谓的模块化就是按照功能
- 看到了很多关于如何读出图片的长度的高度的方法,其实都不实用,大多都是通过图片的大小来判断的,图片的种类众多,通过大小来判断难免要制造很多的代
- 目录概述子查询子查询分类按照查询的返回结果按子查询位置区分select后子查询from后子查询where和having型的子查询单个标量子查
- 本文实例讲述了django框架model orM使用字典作为参数,保存数据的方法。分享给大家供大家参考,具体如下:假设有一个字典,里面已经有
- 本文实例讲述了Python实现去除列表中重复元素的方法。分享给大家供大家参考,具体如下:这里一共使用了四种方法来去除列表中的重复元素,下面是
- (1)标准类型操作符(所有的集合类型)成员关系 (in, not in) &nbs
- 如何获取一个网站的相关信息,获取赶集网的招聘信息,本文为大家介绍利用python获取赶集网招聘信息的关键代码,供大家参考,具体内容如下imp
- 第一:mysql服务的启动和停止net stop mysqlnet start mysql第二:登陆mysql –u用户名 [–h主机名或者
- 1.string.maketrans设置字符串转换规则表(translation table) allchars = string.make
- 下面是用Python实现Floyd算法的代码,供大家参考,具体内容如下# -*- coding: utf-8 -*- ""
- 一、局部变量1 定义在{}里面的变量时局部变量,只能在{}里面有效2 执行到定义的那句话,开始分配内存空间,离开作用域自动进行释放3 作用域
- 我们经常会在登录一个网站的时候被引导页挡住前进的脚步,这一点在上个世纪到本世纪初的网站中尤其明显,特别是在企业网站里,几乎每个企业网站都会有
- 锟拷码和口字码说到乱码问题就不得不提到锟斤拷,这算是非常常见的一种乱码形式,那么它到底是经过何种错误操作产生的呢?下面我们一步步探究。看一个
- 首先是最常规的方法:<p id="para" title="cssrain demo!" on
- 一、uni.navigateTo(OBJECT)保留当前页面,跳转到应用内的某个页面,使用uni.navigateBack可以返回到原页面u