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


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现实多行信息
Aug 26 Javascript
js继承的实现代码
Aug 05 Javascript
js的正则test,match,exec详细解析
Jan 29 Javascript
21个值得收藏的Javascript技巧
Feb 04 Javascript
jquery地址栏链接与a标签链接匹配之特效代码总结
Aug 24 Javascript
js实现字符串和数组之间相互转换操作
Jan 12 Javascript
Vue插件写、用详解(附demo)
Mar 20 Javascript
bootstrap multiselect 多选功能实现方法
Jun 05 Javascript
jQuery表单设置值的方法
Jun 30 jQuery
Javascript实现时间倒计时效果
Jul 15 Javascript
前端跨域的几种解决方式总结(推荐)
Aug 16 Javascript
分析JavaScript数组操作难点
Dec 18 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 stream_get_meta_data返回值
2013/09/29 PHP
使用PHP实现微信摇一摇周边红包
2016/01/04 PHP
php的4种常用运行方式详解
2016/12/22 PHP
js函数名与form表单元素同名冲突的问题
2014/03/07 Javascript
七个很有意思的PHP函数
2014/05/12 Javascript
JS中获取函数调用链所有参数的方法
2015/05/07 Javascript
jquery+CSS3模拟Path2.0动画菜单效果代码
2015/08/31 Javascript
快速解决js开发下拉框中blur与click冲突
2016/10/10 Javascript
浅谈JavaScript中的apply/call/bind和this的使用
2017/02/26 Javascript
EasyUI Datebox 日期验证之开始日期小于结束时间
2017/05/19 Javascript
Angular浏览器插件Batarang介绍及使用
2018/02/07 Javascript
JavaScript求一组数的最小公倍数和最大公约数常用算法详解【面向对象,回归迭代和循环】
2018/05/07 Javascript
前端插件之Bootstrap Dual Listbox使用教程
2019/07/23 Javascript
使用eslint和githooks统一前端风格的技巧
2020/07/29 Javascript
[02:12]2015国际邀请赛 SHOWOPEN
2015/08/05 DOTA
[01:33]真香警告!DOTA2勇士令状不朽珍藏Ⅱ饰品欣赏
2018/06/26 DOTA
python并发2之使用asyncio处理并发
2017/12/21 Python
Python3实现的字典、列表和json对象互转功能示例
2018/05/22 Python
解决python中使用plot画图,图不显示的问题
2018/07/04 Python
Python 输入一个数字判断成绩分数等级的方法
2018/11/15 Python
使用GitHub和Python实现持续部署的方法
2019/05/09 Python
python中append实例用法总结
2019/07/30 Python
python 3.6.7实现端口扫描器
2019/09/04 Python
python安装读取grib库总结(推荐)
2020/06/24 Python
python代码实现图书管理系统
2020/11/30 Python
通过css3动画和opacity透明度实现呼吸灯效果
2019/08/09 HTML / CSS
纯CSS3实现给头像加个光芒四射且旋转的背景动画效果
2014/05/07 HTML / CSS
一款利用纯css3实现的360度翻转按钮的实例教程
2014/11/05 HTML / CSS
web页面录屏实现
2019/02/12 HTML / CSS
Web时代变迁及html5与html4的区别
2016/01/06 HTML / CSS
美国知名日用品连锁超市:Dollar General(多来店)
2017/01/14 全球购物
Lowe’s加拿大:家居装修、翻新和五金店
2019/12/06 全球购物
刑事辩护授权委托书
2014/09/13 职场文书
创业计划书之都市休闲农庄
2019/12/28 职场文书
python执行js代码的方法
2021/05/13 Python
使用javascript解析二维码的三种方式
2021/11/11 Javascript