JS如何使用原生数组splice?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<script>
/*
* splice(start, deleteCount, data1, data2, data3...)
* */
var arr = ['a', 'b', 'c', 'd', 'e'];
//1, 3
// [8,6,4]
//['a',8,6,4]
//arr.splice(-5);
//console.log(arr);
function arrSplice(data, start, deleteCount) {
// 如果start不是数字,或不能转成数字,start默认就为0
if (isNaN(start)) {
start = 0;
}
start = Number(start);
// 如果start是负数
if (start < 0) {
start = data.length + start;
}
if (start < 0) {
start = 0;
}
// 如果deleteCount没传
if (deleteCount == undefined) {
deleteCount = data.length - start;
}
/*
* 1. 准备一个空的数组,用于存放最后的结果
* 2. 循环源数组
* 1. 得到当前循环过程中的下标
* 2. 把这个下标和start做比较
* 1. 如果当前下标小于start,则把当前数组添加到新数组中
* 2. 否则
* 1. 是否有新增数据
* 1. 如果有新在数据,则把新增数据添加到新数组中
* 2. 否则,如果deleteCount大于0,忽略这个数据,并对deleteCount--
* 否则,把当前数据添加到新数组中
* */
var newArr = [];
//新增数据
var newData = [];
if (arguments.length > 3) {
for (var i=3; i<arguments.length; i++) {
// newData.push(arguments[i]);
newData[newData.length] = arguments[i];
}
}
for (var i=0; i<data.length; i++) {
if (i < start) {
// newArr.push(data[i]);
newArr[newArr.length] = data[i];
} else {
if (newData.length) {
//有新增数据的
// newArr = newArr.concat(newData);
for (var j=0; j<newData.length; j++) {
newArr[newArr.length] = newData[j];
}
newData.length = 0;
}
if (deleteCount > 0) {
deleteCount--;
} else {
// newArr.push(data[i]);
newArr[newArr.length] = data[i];
}
}
}
data = newArr;
console.log(data);
}
</script>
</body>
</html>
关于JS如何使用原生数组splice问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。