微信小程序实现左滑删除

效果

实现思路

使用的是官方提供的movable-area 嵌套movable-view

1、movable-area:注意点,需要设置其高度,否则会出现列表内容重叠的现象。

2、由于movable-view需要向右移动,左滑的时候给删除控件展示的空间,故 movable-area 需要左移 left: -180rpx;

3、movable-view右移left: 180rpx;。 通过 width: calc(100% - 180rpx);左划的距离。

4、 需要给movable-view组件设置层级 z-index: 1001;越高越好至少比删除组件层级高,避免被遮住。

源代码如下

.js
javascript 复制代码
 listData: [{
      id: '1',
      name: '这是一个左滑删除功能',
    }, {
      id: '1',
      name: '这是一个左滑删除功能',
    }, {
      id: '1',
      name: '这是一个左滑删除功能',
    }, {
      id: '1',
      name: '这是一个左滑删除功能',
    }, {
      id: '1',
      name: '这是一个左滑删除功能',
    }, ],
.xml
javascript 复制代码
 <scroll-view class='scroll_box' scroll-y='true'>
    <block wx:for="{{listData}}" wx:key="id">
      <movable-area class="moveArea">
        <movable-view class="movableView" direction="horizontal" inertia="{{true}}" out-of-bounds="{{true}}">
          <view style="display: flex;flex-direction: row;width: 100%;height: 100%;">
            <view class="box_item">
              <view class="head_title">
                <text class="before-icon"></text>
                <text>{{item.name}}</text>
              </view>
            </view>
          </view>
        </movable-view>
        <view class="itemDelet">删除</view>
      </movable-area>
    </block>

  </scroll-view>
.css
css 复制代码
.scroll_box {
  /* background-color: #f0f0f0; */
  width: 100%;
  height: calc(100vh - 500rpx);
  margin-top: 28rpx;
  padding: 0 22rpx;
}


/* item盒子 */
.box_item {
  background-color: #fff;
  width: 100%;
  height: 100rpx;
  display: flex;
  align-items: center;
  border-bottom: 2rpx dashed #EDEDED;
  padding-left: 30rpx;
  position: relative;
}


.head_title {
  height: 40rpx;
  font-family: PingFang SC, PingFang SC;
  font-weight: 400;
  font-size: 28rpx;
  color: #14AD00;
  line-height: 38rpx;
  text-align: left;
  font-style: normal;
  display: flex;
  align-items: center;
  text-transform: none;
}

.before-icon {
  display: inline-block;
  width: 9rpx;
  height: 9rpx;
  border-radius: 50%;
  margin-right: 30rpx;
  background: #14AD00;
}

.moveArea {
  display: flex;
  flex-direction: row;
  width: calc(100% + 180rpx);
  justify-content: center;
  left: -180rpx;
  height: 102rpx;
}

.movableView {
  display: flex;
  flex-direction: row;
  width: calc(100% - 180rpx);
  z-index: 1001;
  left: 180rpx;
}

.itemDelet {
  position: absolute;
  right: 0;
  line-height: 100rpx;
  background-color: rgb(252, 65, 65);
  margin-right: 6rpx;
  bottom: 2rpx;
  width: 180rpx;
  text-align: center;
  color: #fff;
}
相关推荐
我命由我12345几秒前
微信小程序 - 页面跳转并传递参数(使用路由参数、使用全局变量、使用本地存储、使用路由参数结合本地存储)
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
00后程序员张5 分钟前
数据流抓包实战指南,TCPUDP 流量分析、HTTPS 解密与多工具协同方案
网络协议·http·ios·小程序·https·uni-app·iphone
2501_9159214322 分钟前
iOS 性能分析工具全景解析,构建从底层诊断到真机监控的多层级性能分析体系
android·ios·小程序·https·uni-app·iphone·webview
2501_9159090626 分钟前
如何防止 IPA 被反编译,从攻防视角构建一套真正有效的 iOS 成品保护体系
android·macos·ios·小程序·uni-app·cocoa·iphone
毕设源码-邱学长37 分钟前
【开题答辩全过程】以 基于微信小程序的社区老年人活动中心信息管理系统的设计与实现 为例,包含答辩的问题和答案
微信小程序·小程序
2501_916007471 小时前
专业的 IPA 处理工具 构建可维护、可回滚的 iOS 成品加工与加固流水线
android·ios·小程序·https·uni-app·iphone·webview
游戏开发爱好者81 小时前
Charles抓包工具怎么用 Charles抓包教程、网络调试技巧与HTTPS配置全流程
网络·ios·小程序·https·uni-app·php·webview
说私域1 小时前
MarTech在客户运营中的作用:以开源AI大模型AI智能名片S2B2C商城小程序为例
人工智能·小程序·开源
烂不烂问厨房1 小时前
支付宝小程序camera录制视频超过30秒无法触发cameraContext.stopRecord回调,也没报错
android·小程序
李慕婉学姐1 小时前
基于微信小程序的康复医疗问诊服务平台5855qb95(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·微信小程序