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


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对select标签的控制(option选项/select)
Jan 31 Javascript
javascript利用apply和arguments复用方法
Nov 25 Javascript
对比分析json及XML
Nov 28 Javascript
JS实现在页面随时自定义背景颜色的方法
Feb 27 Javascript
JavaScript显示表单内元素数量的方法
Apr 02 Javascript
dedecms页面如何获取会员状态的实例代码
Mar 15 Javascript
微信公众平台开发教程(四) 实例入门:机器人回复(附源码)
Dec 02 Javascript
jQuery中Chosen三级联动功能实例代码
Mar 07 Javascript
vue做网页开场视频的实例代码
Oct 20 Javascript
一步步教你利用webpack如何搭一个vue脚手架(超详细讲解和注释)
Jan 08 Javascript
JavaScript类的继承多种实现方法
May 30 Javascript
jQuery实现放大镜案例
Oct 19 jQuery
微信小程序添加插屏广告并设置显示频率(一天一次)
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
php中转义mysql语句的实现代码
2011/06/24 PHP
php获取一个变量的名字的方法
2014/09/05 PHP
php版本CKEditor 4和CKFinder安装及配置方法图文教程
2019/06/05 PHP
JMenuTab简单使用说明
2008/03/13 Javascript
更换select下拉菜单背景样式的实现代码
2011/12/20 Javascript
javascript使用location.search的示例
2013/11/05 Javascript
扩展IE中一些不兼容的方法如contains、startWith等等
2014/01/09 Javascript
jquery实现预览提交的表单代码分享
2014/05/21 Javascript
jquery插件推荐 jquery.cookie
2014/11/09 Javascript
分享一则JavaScript滚动条插件源码
2015/03/03 Javascript
jquery使用on绑定a标签无效 只能用live解决
2016/06/02 Javascript
jQuery学习心得总结(必看篇)
2016/06/10 Javascript
JavaScript 最佳实践:帮你提升代码质量
2016/12/03 Javascript
jQuery实现鼠标跟随效果
2017/02/20 Javascript
BootStrap的两种模态框方式
2017/05/10 Javascript
bootstrap Table插件使用demo
2017/08/07 Javascript
基于vue-cli配置lib-flexible + rem实现移动端自适应
2017/12/26 Javascript
Vue实现active点击切换方法
2018/03/16 Javascript
对Vue- 动态元素属性及v-bind和v-model的区别详解
2018/08/27 Javascript
NodeJs实现简易WEB上传下载服务器
2019/08/10 NodeJs
vue基于better-scroll仿京东分类列表
2020/06/30 Javascript
vue实现单一筛选、删除筛选条件
2020/10/26 Javascript
[57:22]完美世界DOTA2联赛PWL S2 FTD vs PXG 第二场 11.27
2020/12/01 DOTA
python自动化报告的输出用例详解
2018/05/30 Python
使用python批量化音乐文件格式转换的实例
2019/01/09 Python
Django使用消息提示简单的弹出个对话框实例
2019/11/15 Python
python飞机大战游戏实例讲解
2020/12/04 Python
Links of London官方网站:英国标志性的珠宝品牌
2017/04/09 全球购物
家得宝官网:The Home Depot(全球最大的家居装饰专业零售商)
2018/12/17 全球购物
艺术家策划的室内设计:Curious Egg
2019/03/06 全球购物
竞选演讲稿范文
2013/12/28 职场文书
魅力教师事迹材料
2014/01/10 职场文书
活动总结报告范文
2014/05/04 职场文书
不同意离婚答辩状
2015/05/22 职场文书
Python中threading库实现线程锁与释放锁
2021/05/17 Python
python识别围棋定位棋盘位置
2021/07/26 Python