jq使用splice删除数组元素出错的解决方法

简介: jq使用splice删除数组元素出错的解决方法

jq的splice用于删除数组里某些元素,并且会改变原数组

定义和用法

splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目。

注释:该方法会改变原始数组。

语法

arrayObject.splice(index,howmany,item1,.....,itemX)

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

返回值

类型 描述
Array 包含被删除项目的新数组,如果有的话。

说明

splice() 方法可删除从 index 处开始的零个或多个元素,并且用参数列表中声明的一个或多个值来替换那些被删除的元素。

如果从 arrayObject 中删除了元素,则返回的是含有被删除的元素的数组。

浏览器支持

所有主流浏览器都支持 splice() 方法。

提示和注释

注释:请注意,splice() 方法与 slice() 方法的作用是不同的,splice() 方法会直接对数组进行修改。


下面是一个实例

var arr = [1,2,3,4,5,6,7,8,9];

for(i=0;i<arr.length;i++){

arr.splice(2,1);

}

console.log(arr);

输出结果:[1, 2, 8, 9];

是不是和预想的结果不一样?

难道不是就删除arr[2]的属性么,为什么会删除这么多?

原因在于,当删除arr[2],页就是删除3的时候,arr数组将会重新进行计算索引,则那时候的值是

arr=[1,2,4,5,6,7,8,9];i的值为1;那时候的length值为8

第二次循环依然可以删除4;i的值为2;那时候的length值为8

arr=[1,2,5,6,7,8,9];

以此类推,到[1,2,7,8,9]时,i为5,那时候的length值为5;

所以最后一次删除arr[2]时,循环结束

剩余

[1,2,8,9];

所以,当你真正想循环删除数组元素时,在删除之后要i--才能保证循环指针正确指向下一个需要处理的元素上

例如 当你想

var arr = [1,2,3,4,5,6,7,8,9];

for(i=0;i<arr.length;i++){

arr.splice(i,1);

}

console.log(arr);

结果为[2,4,6,8];

var arr = [1,2,3,4,5,6,7,8,9];

for(i=0;i<arr.length;i++){

arr.splice(i,1);

i--;

}

console.log(arr);

结果为空数组


目录
相关文章
|
域名解析 网络协议 Linux
curl 和 wget 的使用和区别
curl 和 wget 的使用和区别
499 0
|
自然语言处理 小程序 数据挖掘
数据分析实战-Python实现博客评论数据的情感分析
数据分析实战-Python实现博客评论数据的情感分析
627 0
|
数据采集 自然语言处理 大数据
​「Python大数据」LDA主题分析模型
使用Python进行文本聚类,流程包括读取VOC数据、jieba分词、去除停用词,应用LDA模型(n_components=5)进行主题分析,并通过pyLDAvis生成可视化HTML。关键代码涉及数据预处理、CountVectorizer、LatentDirichletAllocation以及HTML文件的本地化处理。停用词和业务术语列表用于优化分词效果。
854 0
​「Python大数据」LDA主题分析模型
|
小程序 API
微信小程序更新提醒uniapp
在小程序开发中,版本更新至关重要。本方案利用 `uni-app` 的 `uni.getUpdateManager()` API 在启动时检测版本更新,提示用户并提供立即更新选项,自动下载更新内容,并在更新完成后重启小程序以应用新版本。适用于微信小程序,确保用户始终使用最新版本。以下是实现步骤: ### 实现步骤 1. **创建更新方法**:在 `App.vue` 中创建 `updateApp` 方法用于检查小程序是否有新版本。 2. **测试**:添加编译模式并选择成功状态进行模拟测试。
439 0
微信小程序更新提醒uniapp
|
JavaScript
vue3移动端自适应方案
【8月更文挑战第14天】
824 7
|
存储 缓存 Java
深入理解JMM
深入理解JMM
1112 2
|
设计模式 SQL 前端开发
Java swing+MySQL实现的学生信息管理系统课程设计
这款Java swing实现的学生信息管理系统和jsp版本的功能很相似,简单的实现了班级信息的增删改查,学生信息的增删改查,数据库采用的是mysql,jdk版本不限,是Java学习者学习参考非常好的一个小项目,下面我们来看看如何运行。
|
存储 网络协议 JavaScript
浅谈WebSocket及如何搭建实时聊天系统
WebSocket 是一种在客户端和服务器之间提供全双工、双向通信的网络协议。它是基于TCP/IP协议栈的应用层协议,旨在实现浏览器与服务器之间的实时、低延迟且高效的长连接通信
965 1
|
API Python
Python HTTP请求库对比,以实战请求豆瓣排行榜为例
对比了Python的几个HTTP请求库,包括`requests`、`http.client`、`aiohttp`、`urllib`、`httpx`、`treq`和`requests-toolbelt`,各有特点和优缺点。选择时应考虑项目需求(如异步支持)、易用性、社区支持、性能和兼容性。示例展示了如何使用`requests`和`aiohttp`库发送豆瓣电影排行榜的GET请求。
581 0
|
编译器 程序员 C语言
【GCC 参数】 深入C++编译器常用标志:C/C++ 开发者必备的编译器参数
【GCC 参数】 深入C++编译器常用标志:C/C++ 开发者必备的编译器参数
274 0