js实现数据上移、下移、置顶、置底

1、首先要知道操作数组的几个属性:

unshift():向数组的开头添加一个或更多元素,并返回新的长度。
shift():删除并返回数组的第一个元素。
splice() :删除元素,并向数组添加新元素。
push() :向数组的末尾添加一个或更多元素,并返回新的长度。

2、

// moveId表示那个要被操作的数据下标,index移动位置 1 上移 2 下移  3 置顶 4置底
    moveDataIndex (moveId, index) {
// 为了防止数据抖动先把数据深克隆一份出来
      let moveData = JSON.parse(JSON.stringify(this.tableData))
// 上移
      if (index == 1) { 
        if (moveId != 0) {
          moveData[moveId] = moveData.splice(moveId - 1, 1, moveData[moveId])[0];
        } else {
          moveData.push(moveData.shift());
        }
      }
// 下移
      if (index == 2) {
        if (moveId != moveData.length - 1) {
          moveData[moveId] = moveData.splice(moveId + 1, 1, moveData[moveId])[0];
        } else {
          moveData.unshift(moveData.splice(moveId, 1)[0]);
        }
      }
// 置顶
      if (index == 3) {
        if (moveId != 0) {
          moveData.unshift(moveData.splice(moveId, 1)[0]);
        }
      }
// 置顶
      if (index == 4) {
        if (moveId != moveData.length - 1) {
          moveData.push(moveData.splice(moveId, 1)[0]);
        }
      }
      this.tableData = moveData
    },

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Root1216

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值