微信小程序实现左滑删除

效果

实现思路

使用的是官方提供的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;
}
相关推荐
2501_915909069 小时前
手机崩溃日志导出的工程化体系,从系统级诊断到应用行为分析的多工具协同方法
android·ios·智能手机·小程序·uni-app·iphone·webview
toooooop810 小时前
微信小程序轮播图高度自适应优化
微信小程序·小程序
StarChainTech10 小时前
电动车租赁行业的核心需求:智能中控设备的选择与技术方案
物联网·微信小程序·小程序·软件需求·共享经济
计算机毕设指导612 小时前
基于微信小程序的积分制零食自选平台【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
云起SAAS13 小时前
老年美文文章图文短视频资讯阅读抖音快手微信小程序看广告流量主开源
微信小程序·小程序·ai编程·看广告变现轻·老年美文文章图文短视频资讯阅读
qq_124987075313 小时前
基于微信小程序的民宿预订系统的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·微信小程序·毕业设计
2501_9151063213 小时前
App HTTPS 抓包实战解析,从代理调试到真实网络流量观察的完整抓包思路
网络协议·http·ios·小程序·https·uni-app·iphone
游戏开发爱好者814 小时前
苹果App Store应用程序上架方式全面指南
android·小程序·https·uni-app·iphone·webview
2501_9160088914 小时前
深入理解 iPhone 文件管理,从沙盒结构到开发调试的多工具协同实践
android·ios·小程序·https·uni-app·iphone·webview
说私域15 小时前
人口红利消退与疫情冲击下电商行业的转型路径探索——以开源链动2+1模式S2B2C商城小程序为例
小程序·开源