微信小程序实现单个卡片左滑显示按钮并防止上下滑动干扰功能

作者: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

标签:微信小程序,按钮
0
投稿

猜你喜欢

  • python网络爬虫 CrawlSpider使用详解

    2023-03-19 21:12:56
  • Python实现EM算法实例代码

    2021-05-06 03:02:26
  • Git工作流演示及三种工作方式

    2023-09-12 20:23:05
  • asp Http_Referer,Server_Name和Http_Host

    2011-03-29 11:12:00
  • 详解Python判定IP地址合法性的三种方法

    2021-12-02 14:35:10
  • 浅谈ThinkPHP的URL重写

    2024-05-13 09:24:20
  • Update 语句

    2009-06-22 12:52:00
  • 每天迁移MySQL历史数据到历史库Python脚本

    2024-01-27 20:43:00
  • 爬虫框架 Feapder 和 Scrapy 的对比分析

    2022-03-31 00:02:17
  • 详解如何利用Python绘制迷宫小游戏

    2021-02-28 05:31:32
  • python3中确保枚举值代码分析

    2023-05-23 17:47:31
  • Python的条件语句与运算符优先级详解

    2023-06-21 07:43:49
  • Pytest断言的具体使用

    2023-12-15 06:30:04
  • python使用QQ邮箱实现自动发送邮件

    2021-03-03 22:10:06
  • 详解php中implode explode serialize json msgpack性能对比

    2023-09-03 18:00:19
  • CentOS 7.4 64位安装配置MySQL8.0的详细步骤

    2024-01-16 18:23:43
  • keras 模型参数,模型保存,中间结果输出操作

    2023-06-05 09:52:33
  • 深入分析在Python模块顶层运行的代码引起的一个Bug

    2021-06-29 01:26:29
  • 分享13款非常有用的jQuery插件

    2011-05-16 19:07:00
  • Python中filter与lambda的结合使用详解

    2022-03-03 01:35:03
  • asp之家 网络编程 m.aspxhome.com