微信小程序左滑删除功能开发案例详解


Posted in Javascript onNovember 12, 2018

直接进入正题,我们需要做的就是通过手指滑动列表项后,右侧出现删除;

比如说像这样:

微信小程序左滑删除功能开发案例详解

向左边滑动后出现如下的效果:

微信小程序左滑删除功能开发案例详解

开始撸代码~

假设我们有N个列表项来自一个数组list,先确定基本的结构

<view class="list" wx:for="{{list}}" wx:key>
  <view class="item">
    <view class="wrap">{{item}}</view>
    <view class="delete"><text>删除</text></view>
  </view>
</view>

在item中分别放入wrap作为显示项目内容的容器,与delete删除按钮的容器。

当我们手指向左滑动wrap时,wrap容器向左移动;此时delete从wrap容器之后显示出来;换句话说我们喜欢wrap容器盖住delete,使wrap默认在delete上方。

没错,我们用样式来实现效果。

.item{ position:relative; }
.wrap{ 
 position:absolute;z-index:2; top:0;left:0;
 backgorund:#fff;width:100%;height:100%;
}
.delete{ position:absolute;z-index:1; top:0;right:0;width:120rpx;height:100%;}

好了,这些我们需要的核心样式,为了wrap能100%盖住delete,我们给到它宽高都是百分之百,并且填充背景颜色是必然的,至于要怎么美化可自行添加需要的样式。

基本的结构就到这里了,接下来我们为wrap添加触摸事件;

<view class="wrap" 
 data-index="{{index}}" 
 bindtouchstart='touchstart' 
 bindtouchmove='touchmove' 
 bindtouchend='touchend'
>{{item}}</view>

我们绑定了三个触摸事件,分别是,触摸开始,触摸时移动以及触摸结束。

同时有个wrap添加了data-index="{{index}}" 这样我们就可以确定当前触摸的列表项是哪一个。

接着我们来为他们添加对应的方法。

touchstart:function(e){
  this.setData({
   index: e.currentTarget.dataset.index,
   Mstart: e.changedTouches[0].pageX
  });
 }

通过touchstart方法我们将当前触发事件元素的索引保存到index,并且获得当前手指触摸的坐标位置e.changedTouches[0].pageX;

e.changedTouches[0].pageX

屏幕的左上角的坐标为(0,0),离左上角的距离越大pageX的值也越大。

下一步,当我们移动手指向左滑动时:

touchmove: function (e) {
  //列表项数组
  let list = this.data.list;
  //手指在屏幕上移动的距离
  //移动距离 = 触摸的位置 - 移动后的触摸位置
  let move = this.data.Mstart - e.changedTouches[0].pageX;
  // 这里就使用到我们之前记录的索引index
  //比如你滑动第一个列表项index就是0,第二个列表项就是1,···
  //通过index我们就可以很准确的获得当前触发的元素,当然我们需要在事前为数组list的每一项元素添加x属性
  list[this.data.index].x = move > 0 ? -move : 0;
  this.setData({
   list: list
  });
 }

当移动后的触摸位置小于最初触发的位置时,说明手指是向左滑动,因为pageX越小就越向屏幕边缘靠近;这个时候move就是wrap容器需要向左移动的距离。

我们重写list[this.data.index].x的值,并且将原有的list覆盖,这样我们在滑动的时候就能实时的看到元素跟随手指移动的效果;
这个时候我们可以发现,我们一直往左边移动,wrap元素就会被推到屏幕的边缘;这很明显不是我们想要的效果,我们希望滑动到一定距离后就停止滑动,于是我们为其添加最后一个方法;

touchend: function (e) {
  let list = this.data.list;
  let move = this.data.Mstart - e.changedTouches[0].pageX;
  list[this.data.index].x = move > 100 ? -180 : 0;
  this.setData({
   list: list
  });
 },

我们看到这个方法唯一的不同的地方是这一行

list[this.data.index].x = move > 100 ? -180 : 0

意思是当手指离开元素时,如果移动的距离大于100,那么元素将自动向左移动到180的距离,如果小于100那么元素将向右恢复。

接着我们给wrap元素添加style,这样它就能获得移动的距离x。

至于为什么要移动距离要除以2,这个跟小程序使用rpx单位有关系;

之前我们写100,-180是像素px,需要换算成rpx;

微信小程序开发尺寸单位文档

设备 rpx换算px (屏幕宽度/750) px换算rpx (750/屏幕宽度)
iPhone5,1rpx = 0.42px,1px = 2.34rpx
iPhone6,1rpx = 0.5px,1px = 2rpx
iPhone6 Plus,1rpx = 0.552px,1px = 1.81rpx

我们看到基本是2倍的比例;

<view class="wrap" 
 style="transform:translateX({{item.x/2}}px);"
 data-index="{{index}}" 
 bindtouchstart='touchstart' 
 bindtouchmove='touchmove' 
 bindtouchend='touchend'
>{{item}}</view>

最后我们使用样式为wrap元素添加过渡效果就基本完成了。

源码地址:https://github.com/749264345/wechat-weapp-map

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript实现检查页面上的广告是否被AdBlock屏蔽了的方法
Nov 03 Javascript
javascript鼠标滑动评分控件完整实例
May 13 Javascript
JavaScript实现列表分页功能特效
May 15 Javascript
JQuery中DOM实现事件移除的方法
Jun 13 Javascript
jQuery实现自动调整字体大小的方法
Jun 15 Javascript
微信js-sdk分享功能接口常用逻辑封装示例
Oct 13 Javascript
使用微信小程序开发前端【快速入门】
Dec 05 Javascript
深入理解Angular中的依赖注入
Jun 26 Javascript
React从react-router路由上做登陆验证控制的方法
May 10 Javascript
mpvue全局引入sass文件的方法步骤
Mar 06 Javascript
Vue.directive 实现元素scroll逻辑复用
Nov 29 Javascript
vue自动添加浏览器兼容前后缀操作
Aug 13 Javascript
微信运维交互机器人的示例代码
Nov 12 #Javascript
用jQuery将JavaScript对象转换为querystring查询字符串的方法
Nov 12 #jQuery
手动下载Chrome并解决puppeteer无法使用问题
Nov 12 #Javascript
vue elementui form表单验证的实现
Nov 11 #Javascript
跨域请求两种方法 jsonp和cors的实现
Nov 11 #Javascript
浅谈webpack+react多页面开发终极架构
Nov 11 #Javascript
Vue项目引进ElementUI组件的方法
Nov 11 #Javascript
You might like
php调用mysql存储过程
2007/02/14 PHP
坏狼的PHP学习教程之第1天
2008/06/15 PHP
PHP日期时间函数的高级应用技巧
2009/05/16 PHP
PHP安全技术之 实现php基本安全
2010/09/04 PHP
smarty简单入门实例
2014/11/28 PHP
php获取字符串中各个字符出现次数的方法
2015/02/23 PHP
PHP针对中英文混合字符串长度判断及截取方法示例
2017/03/31 PHP
javascript实现的使用方向键控制光标在table单元格中切换
2010/11/17 Javascript
jquery验证手机号码、邮箱格式是否正确示例代码
2013/07/28 Javascript
js跳转页面方法实现汇总
2014/02/11 Javascript
多种JQuery循环滚动文字图片效果代码
2020/06/23 Javascript
Javascript中的arguments对象
2016/06/20 Javascript
jQuery自定义元素右键点击事件(实现案例)
2017/04/28 jQuery
vue2.0 中#$emit,$on的使用详解
2017/06/07 Javascript
vue实现某元素吸顶或固定位置显示(监听滚动事件)
2017/12/13 Javascript
vue 实现全选全不选的示例代码
2018/03/29 Javascript
JavaScript递归函数解“汉诺塔”算法代码解析
2018/07/05 Javascript
vue中Element-ui 输入银行账号每四位加一个空格的实现代码
2018/09/14 Javascript
浅谈Angular单元测试总结
2019/03/22 Javascript
jQuery实现聊天对话框
2020/02/08 jQuery
详解ES6 中的Object.assign()的用法实例代码
2021/01/11 Javascript
vue中h5端打开app(判断是安卓还是苹果)
2021/02/26 Vue.js
[01:01:23]完美世界DOTA2联赛PWL S2 Forest vs FTD.C 第一场 11.26
2020/11/30 DOTA
python读取浮点数和读取文本文件示例
2014/05/06 Python
Python中的CURL PycURL使用例子
2014/06/01 Python
Python程序设计入门(2)变量类型简介
2014/06/16 Python
Python迭代器和生成器介绍
2015/03/06 Python
python如何压缩新文件到已有ZIP文件
2018/03/14 Python
python 瀑布线指标编写实例
2020/06/03 Python
受希腊女神灵感的晚礼服、鸡尾酒礼服和婚纱:THEIA
2018/04/15 全球购物
澳大利亚购买太阳镜和眼镜网站:Glamoureyes
2020/09/22 全球购物
战友聚会邀请函
2014/01/18 职场文书
高中学生评语大全
2014/04/25 职场文书
实习生矿工检讨书
2014/10/13 职场文书
装修公司工程部经理岗位职责
2015/04/09 职场文书
python 详解turtle画爱心代码
2022/02/15 Python