JS删除指定下标的元素

3 篇文章 0 订阅
2 篇文章 0 订阅

在开发过程中,有时我们需要删除数组中某一下标的元素。JAVA中ArrayList有remove函数。但是在JavaScript中没有直接的删除方法。我们可以利用splice来实现。
Array.splice()定义:splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目。注意: 该方法会改变原始数组。

参数描述
index必需。整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。
howmany必需。要删除的项目数量。如果设置为 0,则不会删除项目。
item1, …, itemX可选。向数组添加的新项目。

例如:

			let arr = ["james","irving","kobe","wade"];
			arr.splice(1,1) //在下标1处开始删除,删除一位
			console.log(arr);// irving被删除

结果:
在这里插入图片描述

在vue+elementui 开发过程中,利用这点可以实现表格删除一行数据后,不用再次请求查询接口即可实现页面刷新.
思路就是在删除成功后的回调函数中删除原tableData中被删除的那条数据.
template代码:
通过 Scoped slot 可以获取到 row, column, $index 和 store(table 内部的状态管理)的数据.

			<el-table-column label="操作" width="100">
                <template slot-scope="scope">
                    <el-button @click="handleDelete(scope.$index, scope.row)" type="text" size="small">删除</el-button>
                    <el-button type="text" size="small">编辑</el-button>
                </template>
            </el-table-column>

js methods中的删除方法

			handleDelete(index, row) {
                //console.log(index)
                //console.log(row)
                this.tableData.splice(index, 1);
            }

这样在删除成功后就不用多请求一次查询接口。
但是这么做不适合带分页的table,因为常规情况下分页是请求当前页中规定的数目数据。删除一个后当前页就会少一条数据。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值