微信小程序左右滑动删除事件如何实现?

2026-04-02 22:341阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计796个文字,预计阅读时间需要4分钟。

微信小程序左右滑动删除事件如何实现?

原文示例:本文字例为大家分享了微信小程序左右滑动删除事件的实现,供大家参考。具体内容如下+效果图+上古代码+scroll-view scroll-y enable-back-to-top style=height: {{scrollHeight}}px view block wx:for=

改写后:分享微信小程序左右滑动删除功能实现,详情如下+效果展示+代码示例+scroll-view scroll-y enable-back-to-top style=height: {{scrollHeight}}px view block wx:for=%

本文实例为大家分享了微信小程序左右滑动删除事件,供大家参考,具体内容如下

效果图

上代码

<scroll-view scroll-y enable-back-to-top style="height:{{ scrollHeight }}px" >     <view>         <block wx:for="{{ list }}" wx:for-item="item" wx:for-index="index" wx:key="index" >             <view class="list {{ item.isTouchMove ? 'touch-move-active' : '' }}"    bindtouchstart="touchStart" bindtouchmove="touchMove" data-index="{{ index }}" >                 <view class="txt">{{ item.id }} -- {{ item.title }}</view>                 <view class="del" bindtap="delList" data-index="{{ index }}" > 删除 </view>             </view>         </block>     </view> </scroll-view>

/* 列表 */ .list {     display: flex;     justify-content: space-between;     width: 100%;     height: 100rpx;     line-height: 100rpx;     overflow: hidden;     text-align: center;     border-bottom: 1px solid #cccccc; } /* 列表内容 */ .list .txt {     flex-grow: 1;     width: 100%;     margin-left: -150rpx;     background-color: #fff; } /* 删除按钮 */ .list .del {     flex-grow: 0;     width: 150rpx;     color: #fff;     background-color: #fe3e2f; } .list .txt, .list .del {     transform: translateX(150rpx);     transition: all 0.4s; } .touch-move-active .txt,.touch-move-active .del {     -webkit-transform: translateX(0);     transform: translateX(0); }

js:

微信小程序左右滑动删除事件如何实现?

Page({     /**      * 页面的初始数据      */     data: {         list: [             { id: "0001", title: "商品1" },             { id: "0002", title: "商品2" },             // ..........         ],         scrollHeight: 0,  // scroll-view高度         startX: 0,        // 开始X坐标         startY: 0,        // 开始Y坐标     },     // 手指触摸动作开始     touchStart: function(e){         let that = this;         //开始触摸时 重置所有删除         that.data.list.forEach(function (v, i) {             if (v.isTouchMove) v.isTouchMove = false; // 只操作为true的         })         // 记录手指触摸开始坐标         that.setData({             startX: e.changedTouches[0].clientX,  // 开始X坐标             startY: e.changedTouches[0].clientY,  // 开始Y坐标             list: that.data.list         })     },     // 手指触摸后移动     touchMove: function(e){         let that = this,             index = e.currentTarget.dataset.index,    // 当前下标             startX = that.data.startX,                // 开始X坐标             startY = that.data.startY,                // 开始Y坐标             touchMoveX = e.changedTouches[0].clientX, // 滑动变化坐标             touchMoveY = e.changedTouches[0].clientY, // 滑动变化坐标             // 获取滑动角度             angle = that.angle({ X: startX, Y: startY }, { X: touchMoveX, Y: touchMoveY });      // 判断滑动角度         that.data.list.forEach(function (v, i) {             v.isTouchMove = false             // 滑动超过30度角 return             if (Math.abs(angle) > 30) return;             if (i == index) {                 // 右滑                 if (touchMoveX > startX)                      v.isTouchMove = false                 // 左滑                 else                      v.isTouchMove = true             }       })       // 更新数据       that.setData({           list: that.data.list       })     },     // 计算滑动角度     angle: function (start, end) {         let that = this,             _X = end.X - start.X,             _Y = end.Y - start.Y;         // 返回角度 /Math.atan()返回数字的反正切值         return 360 * Math.atan(_Y / _X) / (2 * Math.PI);     },     // 删除     delList: function(e){         let that = this,             index = e.currentTarget.dataset.index;  // 当前下标      // 切割当前下标元素,更新数据         that.data.list.splice(index, 1);          that.setData({             list: that.data.list         })     },     /**      * 生命周期函数--监听页面加载      */     onLoad: function (options) {         let that = this;         // 动态获取屏幕高度         that.setData({             scrollHeight: wx.getSystemInfoSync().screenHeight         })     }, })

这是左滑动删除,如需要右滑动删除在js页面调整一下就好。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。

本文共计796个文字,预计阅读时间需要4分钟。

微信小程序左右滑动删除事件如何实现?

原文示例:本文字例为大家分享了微信小程序左右滑动删除事件的实现,供大家参考。具体内容如下+效果图+上古代码+scroll-view scroll-y enable-back-to-top style=height: {{scrollHeight}}px view block wx:for=

改写后:分享微信小程序左右滑动删除功能实现,详情如下+效果展示+代码示例+scroll-view scroll-y enable-back-to-top style=height: {{scrollHeight}}px view block wx:for=%

本文实例为大家分享了微信小程序左右滑动删除事件,供大家参考,具体内容如下

效果图

上代码

<scroll-view scroll-y enable-back-to-top style="height:{{ scrollHeight }}px" >     <view>         <block wx:for="{{ list }}" wx:for-item="item" wx:for-index="index" wx:key="index" >             <view class="list {{ item.isTouchMove ? 'touch-move-active' : '' }}"    bindtouchstart="touchStart" bindtouchmove="touchMove" data-index="{{ index }}" >                 <view class="txt">{{ item.id }} -- {{ item.title }}</view>                 <view class="del" bindtap="delList" data-index="{{ index }}" > 删除 </view>             </view>         </block>     </view> </scroll-view>

/* 列表 */ .list {     display: flex;     justify-content: space-between;     width: 100%;     height: 100rpx;     line-height: 100rpx;     overflow: hidden;     text-align: center;     border-bottom: 1px solid #cccccc; } /* 列表内容 */ .list .txt {     flex-grow: 1;     width: 100%;     margin-left: -150rpx;     background-color: #fff; } /* 删除按钮 */ .list .del {     flex-grow: 0;     width: 150rpx;     color: #fff;     background-color: #fe3e2f; } .list .txt, .list .del {     transform: translateX(150rpx);     transition: all 0.4s; } .touch-move-active .txt,.touch-move-active .del {     -webkit-transform: translateX(0);     transform: translateX(0); }

js:

微信小程序左右滑动删除事件如何实现?

Page({     /**      * 页面的初始数据      */     data: {         list: [             { id: "0001", title: "商品1" },             { id: "0002", title: "商品2" },             // ..........         ],         scrollHeight: 0,  // scroll-view高度         startX: 0,        // 开始X坐标         startY: 0,        // 开始Y坐标     },     // 手指触摸动作开始     touchStart: function(e){         let that = this;         //开始触摸时 重置所有删除         that.data.list.forEach(function (v, i) {             if (v.isTouchMove) v.isTouchMove = false; // 只操作为true的         })         // 记录手指触摸开始坐标         that.setData({             startX: e.changedTouches[0].clientX,  // 开始X坐标             startY: e.changedTouches[0].clientY,  // 开始Y坐标             list: that.data.list         })     },     // 手指触摸后移动     touchMove: function(e){         let that = this,             index = e.currentTarget.dataset.index,    // 当前下标             startX = that.data.startX,                // 开始X坐标             startY = that.data.startY,                // 开始Y坐标             touchMoveX = e.changedTouches[0].clientX, // 滑动变化坐标             touchMoveY = e.changedTouches[0].clientY, // 滑动变化坐标             // 获取滑动角度             angle = that.angle({ X: startX, Y: startY }, { X: touchMoveX, Y: touchMoveY });      // 判断滑动角度         that.data.list.forEach(function (v, i) {             v.isTouchMove = false             // 滑动超过30度角 return             if (Math.abs(angle) > 30) return;             if (i == index) {                 // 右滑                 if (touchMoveX > startX)                      v.isTouchMove = false                 // 左滑                 else                      v.isTouchMove = true             }       })       // 更新数据       that.setData({           list: that.data.list       })     },     // 计算滑动角度     angle: function (start, end) {         let that = this,             _X = end.X - start.X,             _Y = end.Y - start.Y;         // 返回角度 /Math.atan()返回数字的反正切值         return 360 * Math.atan(_Y / _X) / (2 * Math.PI);     },     // 删除     delList: function(e){         let that = this,             index = e.currentTarget.dataset.index;  // 当前下标      // 切割当前下标元素,更新数据         that.data.list.splice(index, 1);          that.setData({             list: that.data.list         })     },     /**      * 生命周期函数--监听页面加载      */     onLoad: function (options) {         let that = this;         // 动态获取屏幕高度         that.setData({             scrollHeight: wx.getSystemInfoSync().screenHeight         })     }, })

这是左滑动删除,如需要右滑动删除在js页面调整一下就好。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。