小程序 — 实现左滑删除效果(列表)③

作者 : 开心源码 本文共935个字,预计阅读时间需要3分钟 发布时间: 2022-05-12 共173人阅读

前言:实现完整的列表左滑删除功能。
GitHub: Ewall1106/miniProgramDemo

1、列表渲染

首先我们初始化一个list列表并为其增加数据,这个列表有两个值分别为标题文字title和初始的偏移量x

list: [  {    x: 0,    title: '这里是内容区域0'  },  {    x: 0,    title: '这里是内容区域1'  },  {    x: 0,    title: '这里是内容区域2'  },  {    x: 0,    title: '这里是内容区域3'  }],// 记录当前偏移量currentX: 0

而后我们在页面上循环渲染这个列表,这里就不多说了。

2、事件解决

(1)首先我们要给touchend事件传递一个参数,参数值为当前使用户触摸列表的索引值,让我们可以知道,究竟使用户是触摸了哪个列表项。
(2)而后我们要在触摸事件结束的时候判断偏移量的位置

handleTouchend(idx, e) {  if (this.currentX < -46) {    this.list[idx].x = -92;    this.setData({      list: this.list    });  } else {    this.list[idx].x = 0;    this.setData({      list: this.list    });  }}
  • 上面几行代码很重要,处理了这么一个问题:
    列表渲染的问题,因为js的限制,不能检测到数组中值的变化,所以我们先改变了list数组项中的值,而后在使用this.setData()重新赋值一遍,关于这个问题,可以看看vue中关于列表渲染的注意事项,原理是一样的:https://cn.vuejs.org/v2/guide/list.html#%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9

(3)最后就是删除功能的实现

同理我们也需要获取使用户点击删除按钮的索引值,而后进行删除,很简单不多说,看代码:

handleDelete(idx) {  this.list.splice(idx, 1);  this.setData({    list: this.list  });}

3、小结

这就是我们实现左滑删除效果的一律内容了,利使用了小程序的movable组件实现了大部分的功能,关于js主要是在解决列表渲染的时候,这里是个坑,其余就没什么难点了,看看最后的效果图吧:

最终效果

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 小程序 — 实现左滑删除效果(列表)③

发表回复