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


Posted in Javascript onDecember 06, 2019

实现类似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
    });
  }
}

总结

以上所述是小编给大家介绍的微信小程序实现单个卡片左滑显示按钮并防止上下滑动干扰功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
javascript下IE与FF兼容函数收集
Sep 17 Javascript
jquery自动填充勾选框即把勾选框打上true
Mar 24 Javascript
基于jquery的文字向上跑动类似跑马灯的效果
Sep 22 Javascript
JavaScript实现列出数组中最长的连续数
Dec 29 Javascript
使用jQuery实现input数值增量和减量的方法
Jan 24 Javascript
JS实现的页面自定义滚动条效果
Oct 26 Javascript
jQuery+canvas实现的球体平抛及颜色动态变换效果
Jan 28 Javascript
关于Javascript中defer和async的区别总结
Sep 20 Javascript
jquery实现下拉框左右选择功能
Feb 21 Javascript
微信小程序实现折叠与展开文章功能
Jun 12 Javascript
微信小程序实现文字从右向左无限滚动
Nov 18 Javascript
JS实现TITLE悬停长久显示效果完整示例
Feb 11 Javascript
微信小程序添加插屏广告并设置显示频率(一天一次)
Dec 06 #Javascript
微信小程序激励式视频广告组件使用详解
Dec 06 #Javascript
微信小程序中限制激励式视频广告位显示次数(实现思路)
Dec 06 #Javascript
vue中监听路由参数的变化及方法
Dec 06 #Javascript
详解ECMAScript2019/ES10新属性
Dec 06 #Javascript
ES6的异步操作之promise用法和async函数的具体使用
Dec 06 #Javascript
原生JavaScript实现滑动拖动验证的示例代码
Dec 06 #Javascript
You might like
Zend Framework实现自定义过滤器的方法
2016/12/09 PHP
Laravel实现ApiToken认证请求
2019/10/14 PHP
Thinkphp页面跳转设置跳转等待时间的操作
2019/10/16 PHP
ThinkPHP5与单元测试PHPUnit使用详解
2020/02/23 PHP
JSON 数据格式介绍
2012/01/13 Javascript
JavaScript中“过于”犀利地for/in循环使用示例
2013/10/22 Javascript
jQuery实现返回顶部效果的方法
2015/05/29 Javascript
Vue制作Todo List网页
2017/04/26 Javascript
node实现爬虫的几种简易方式
2019/08/22 Javascript
基于小程序请求接口wx.request封装的类axios请求
2020/07/02 Javascript
[02:36]DOTA2混沌骑士 英雄基础教程
2013/11/26 DOTA
Python深入学习之特殊方法与多范式
2014/08/31 Python
python多重继承实例
2014/10/11 Python
Python的设计模式编程入门指南
2015/04/02 Python
Python字符串转换成浮点数函数分享
2015/07/24 Python
浅谈解除装饰器作用(python3新增)
2018/10/15 Python
Python2.7版os.path.isdir中文路径返回false的解决方法
2019/06/21 Python
如何利用Python开发一个简单的猜数字游戏
2019/09/22 Python
pygame实现俄罗斯方块游戏(基础篇1)
2019/10/29 Python
Python for循环及基础用法详解
2019/11/08 Python
python3+opencv 使用灰度直方图来判断图片的亮暗操作
2020/06/02 Python
在pycharm中文件取消用 pytest模式打开的操作
2020/09/01 Python
matplotlib绘制鼠标的十字光标的实现(自定义方式,官方实例)
2021/01/10 Python
python SOCKET编程基础入门
2021/02/27 Python
详解移动端HTML5页面端去掉input输入框的白色背景和边框(兼容Android和ios)
2016/12/15 HTML / CSS
详解canvas.toDataURL()报错的解决方案全都在这了
2020/03/31 HTML / CSS
捷克家电和家具购物网站:OKAY.cz
2020/07/23 全球购物
厨房工作人员岗位职责
2013/11/15 职场文书
学生自我鉴定格式及范文
2014/09/16 职场文书
个人反四风对照检查材料思想汇报
2014/09/23 职场文书
高一作文之乐趣
2019/11/21 职场文书
详解CocosCreator项目结构机制
2021/04/14 Javascript
MySQL8.0.24版本Release Note的一些改进点
2021/04/22 MySQL
分析Netty直接内存原理及应用
2021/06/14 Java/Android
Python常用配置文件ini、json、yaml读写总结
2021/07/09 Python
Spring this调用当前类方法无法拦截的示例代码
2022/03/20 Java/Android