uniapp 实现滑动元素删除效果

官网地址:uni-app官网 (dcloud.net.cn)

最终效果如下图:

滑动删除需要用到 uni-ui 的 uni-swipe-action 组件和 uni-swipe-action-item

属性名 类型 可选值 默认值 是否必填 说明
left-options Array/Object - - 左侧选项内容及样式
right-options Array/Object - - 右侧选项内容及样式
html 复制代码
    下面的 block 元素,循环出所有的商品元素

    <!-- uni-swipe-action 是最外层包裹性质的容器 -->
    <uni-swipe-action>
      <block v-for="(goods, i) in cart" :key="i">
          <!-- uni-swipe-action-item 可以为其子节点提供滑动操作的效果。需要通过 options 属性来指定操作按钮的配置信息 -->
          <uni-swipe-action-item :right-options="options" @click="onClick(goods)">
            <!-- ================================== -->
            <view style="height: 300rpx;background-color: pink;">
              根据自己需要,配置 需要的样式
            </view>
            <!-- ================================== -->
          </uni-swipe-action-item>
      </block>
    </uni-swipe-action>

配置option项、所有商品对象:

参数 类型 是否必填 说明
text String 按钮的文字
style Object 按钮样式{backgroundColor,color,fontSize},backgroundColor默认为:#C7C6CD,color默认为:#FFFFFF,fontSize默认为:14px
javascript 复制代码
    data() {
      return {
        // 这个是所有商品对象
        cart: [{
            goods_id: 1,
        },{
            good_id: 2
        }],

        // 这个是滑动后的配置项
        options: [{
          text: '删除', // 显示的文本内容
          style: {
            backgroundColor: '#C00000' // 按钮的背景颜色
          }
        }]
      }
    },

可用的事件:【我们需要的是滑动点击删除,用了 @click 事件,并传递 货品 id】

事件称名 说明 返回值
@click 点击选项按钮时触发事件 e = {content,index} ,content(点击内容)、index(下标)、position (位置信息)
@change 组件打开或关闭时触发 left:左侧 ,right:右侧,none:关闭

得到下面的效果图:

使用 filter 方法,使返回值为 不存在 刚刚传进来滑动删除 对应货品id 的对象

javascript 复制代码
  methods: {
    // 根据 Id 从购物车中删除对应的商品信息
    onClick(goods_id) {
      // 调用数组的 filter 方法进行过滤
      this.cart = this.cart.filter(x => x.goods_id !== goods_id)
    },
  }
相关推荐
逸模2 小时前
告别熬夜手工整理台账,逸模智能归集实现项目数据自动化存档
大数据·运维·人工智能·笔记·其他·信息可视化·自动化
sbjdhjd2 小时前
Redis 主从复制、哨兵高可用与 Cluster 集群部署实验手册
运维·前端·redis·云原生·开源·bootstrap·html
Frostnova丶2 小时前
【算法笔记】数学知识
笔记·算法
乐兮创想 小林2 小时前
企业官网移动端性能优化实战:从 Core Web Vitals 到图片/CDN/响应式的工程清单
前端·性能优化·网站建设·北京网站建设公司
xqqxqxxq2 小时前
哈希表(HashMap)技术学习笔记
笔记·学习·散列表
AOwhisky3 小时前
MySQL 学习笔记(第四期):SQL 语言之多表查询
linux·运维·网络·数据库·笔记·学习·mysql
前端一小卒3 小时前
不手写代码的第 30 天,我才明白前端这个岗位还剩什么
前端·javascript·ai编程
Ajie'Blog3 小时前
Copilot Agent Tasks API 开放:AI 编程开始进入后台任务时代
服务器·前端·javascript·人工智能·copilot·ai编程
老毛肚3 小时前
jeecgboot vue TS & 模板化 04
前端·javascript·vue.js
xian_wwq3 小时前
【学习笔记】「大模型安全:攻击面演化史」第 07 篇-安全左移
人工智能·笔记·学习