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


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 相关文章推荐
用cookies实现的可记忆的样式切换效果代码下载
Dec 24 Javascript
微信小程序 表单Form实例详解(附源码)
Dec 22 Javascript
js实现符合国情的日期插件详解
Jan 19 Javascript
jQuery实现定时隐藏对话框的方法分析
Feb 12 jQuery
Vue 使用 Mint UI 实现左滑删除效果CellSwipe
Apr 27 Javascript
vue-cli构建项目下使用微信分享功能
May 28 Javascript
解决vue 打包发布去#和页面空白的问题
Sep 04 Javascript
vue.js指令v-for使用以及下标索引的获取
Jan 31 Javascript
利用Vue-draggable组件实现Vue项目中表格内容的拖拽排序
Jun 07 Javascript
微信小程序激励式视频广告组件使用详解
Dec 06 Javascript
javascript实现获取中文汉字拼音首字母
May 19 Javascript
详解三种方式在React中解决绑定this的作用域问题并传参
Aug 18 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
php下检测字符串是否是utf8编码的代码
2008/06/28 PHP
rrmdir php中递归删除目录及目录下的文件
2011/05/15 PHP
初识php MVC
2014/09/10 PHP
PHP中preg_match函数正则匹配的字符串长度问题
2015/05/27 PHP
yii2 modal弹窗之ActiveForm ajax表单异步验证
2016/06/13 PHP
Zend Framework入门应用实例详解
2016/12/11 PHP
PHP回调函数概念与用法实例分析
2017/11/03 PHP
根据地区不同显示时间的javascript代码
2007/08/13 Javascript
IE8 浏览器Cookie的处理
2009/01/31 Javascript
返回对象在当前级别中是第几个元素的实现代码
2011/01/20 Javascript
Javascript处理DOM元素事件实现代码
2012/05/23 Javascript
js对字符的验证方法汇总
2015/02/04 Javascript
JQUERY实现网页右下角固定位置展开关闭特效的方法
2015/07/27 Javascript
jQuery实现的模拟弹出窗口功能示例
2016/11/24 Javascript
详解Nodejs 通过 fs.createWriteStream 保存文件
2017/10/10 NodeJs
详解在Vue中使用TypeScript的一些思考(实践)
2018/07/06 Javascript
用VueJS写一个Chrome浏览器插件的实现方法
2019/02/27 Javascript
vue使用swiper实现中间大两边小的轮播图效果
2019/11/24 Javascript
Python中的MongoDB基本操作:连接、查询实例
2015/02/13 Python
python获取android设备的GPS信息脚本分享
2015/03/06 Python
Python合并两个字典的常用方法与效率比较
2015/06/17 Python
pycharm 实现显示project 选项卡的方法
2019/01/17 Python
python实现猜拳小游戏
2020/04/05 Python
Python如何应用cx_Oracle获取oracle中的clob字段问题
2019/08/27 Python
浅谈Python type的使用
2019/11/19 Python
Python selenium环境搭建实现过程解析
2020/09/08 Python
全球知名旅游社区巴西站点:TripAdvisor巴西
2016/07/21 全球购物
美国花布包包品牌:Vera Bradley
2017/08/11 全球购物
尽职尽责村干部自我鉴定
2014/01/23 职场文书
化工操作工岗位职责
2014/04/29 职场文书
注册资产评估专业求职信
2014/07/16 职场文书
给老婆的检讨书1000字
2015/01/01 职场文书
英文感谢信范文
2015/01/21 职场文书
Jedis操作Redis实现模拟验证码发送功能
2021/09/25 Redis
JavaScript实现一键复制内容剪贴板
2022/07/23 Javascript
使用CSS实现音波加载效果
2023/05/07 HTML / CSS