时间:2021-05-18
直接进入正题,我们需要做的就是通过手指滑动列表项后,右侧出现删除;
比如说像这样:
向左边滑动后出现如下的效果:
开始撸代码~
假设我们有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元素就会被推到屏幕的边缘;这很明显不是我们想要的效果,我们希望滑动到一定距离后就停止滑动,于是我们为其添加最后一个方法;
我们看到这个方法唯一的不同的地方是这一行
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/屏幕宽度)我们看到基本是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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
微信小程序侧滑删除(左滑删除)如图所示,demo是小程序的侧滑删除,这个是我在别人写的例子的基础上修改的。代码如下js文件代码://pages/leftSwip
微信小程序实现左滑删除效果的具体代码,供大家参考,具体内容如下.wxml{{item.content}}删除.jsPage({data:{delBtnWidth
什么?微信或推出小程序全新入口“小程序桌面”,有图有真相:如上图,一段网传的视频显示微信正在做小程序入口“小程序桌面”,打开微信主页面左滑即可进入“小程序桌面”
微信小程序Mustache语法详解最近微信小程序非常火,对于前端开发的程序员是个利好的消息,这里主要记录下微信小程序Mustache语法。小程序开发的wxml里
一般的商城平台都有一个必备的功能,就是客服功能。当然现在火热的微信小程序商城也能开发客服功能。但是模板跟定制的结果还会存在差异,以定制开发的方式去实现微信小程序