javascript中的数组如何使用?_学习javascript数组操作方法【教程】
技术百科
夜晨
发布时间:2026-01-28
浏览: 次 JavaScript数组是带整数索引的普通对象,length为最大整数索引加1;includes()比indexOf()更可靠,尤其处理NaN;flat()默认只展平一层,无限展平用flat(Infinity)。
JavaScript 数组不是“容器”,而是一个带整数索引的普通对象,它的行为由 length 属性和内置方法共同控制——这意味着很多看似直观的操作,其实有隐含规则。
为什么 arr[5] = 'x' 后 arr.length 变成 6?
数组的 length 不是元素个数统计结果,而是“最大整数索引 + 1”。当你直接赋值 arr[5],即使 arr[0] 到 arr[4] 都是 undefined,length 也会自动设为 6。
- 这种写法会创建稀疏数组(sparse array),
for...of和forEach()会跳过空位,但for (let i = 0; i 仍会遍历到这些位置 - 避免用下标越界赋值来“扩容”,改用
push()、concat()或扩展运算符[...arr, 'x'] -
Array(5)创建的是 5 个空位的数组(非undefined元素),它和[undefined, undefined, undefined, undefined, undefined]行为不同
map() 和 filter() 返回新数组,但 push()、sort() 会修改原数组
这是最常引发 bug 的混淆点:一部分方法是纯函数式(不改变原数组),另一部分是就地操作(mutating)。
- 纯函数式方法:
map()、filter()、slice()、concat()、flatMap()、扩展运算符[...arr] - 就地修改方法:
push()、pop()、shift()、unshift()、splice()、sort()、reverse() -
sort()默认按字符串排序:[10, 2, 1].sort()得到[1, 10, 2];数字排序必须传比较函数:.sort((a, b) => a - b)
用 includes() 判断存在,别用 indexOf() === -1
includes() 是 ES2016 引入的语义更清晰的方法,它能正确处理 NaN,而 indexOf() 不能:
const arr = [NaN]; arr.indexOf(NaN); // -1 arr.includes(NaN); // true
-
includes()使用 SameValueZero 算法,与===基本一致(唯一例外是NaN) - 需要获取索引时才用
indexOf()或findIndex();仅判断存在性,优先选includes() - 对象数组中查找需用
some():arr.some(item => item.id === 123)
flat() 处理嵌套数

flat() 默认深度为 1,遇到多层嵌套(如 [[[1, 2], 3], 4])不会完全展平:
-
[1, [2, [3]]].flat()→[1, 2, [3]] - 无限展平用
.flat(Infinity),但要注意性能和循环引用风险 - 替代方案:
JSON.parse(JSON.stringify(arr))不适用于函数、undefined、Date等,慎用 - 需要条件过滤+展平时,
flatMap()更高效:arr.flatMap(x => x.enabled ? [x.value] : [])
数组方法的行为差异往往藏在规范细节里,比如 forEach() 跳过空位、reduce() 第二次调用时的初始值逻辑、find() 对 NaN 的处理——这些不是边缘情况,而是日常调试中突然出现 undefined 的根源。
# 的是
# 都是
# 这是
# 也会
# 当你
# 藏在
# 跳过
# 设为
# js
# json
# 循环
# 对象
# javascript
# java
# 字符串
# 为什么
# red
# bug
# foreach
# 算法
# map
# 运算符
# 遍历
# for
# sort
# undefined
# Filter
# Length
# date
# Array
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- windows 10应用商店区域怎么改_windo
- 如何有效拦截拼接式恶意域名的垃圾信息
- 微信短链接怎么还原php_用浏览器开发者工具抓包获
- ACF 教程:如何正确更新嵌套在多层 Group
- Mac如何修改Hosts文件?(本地开发与屏蔽网站
- Win10怎么更改用户名 Win10修改账户名称操
- Win11 explorer.exe频繁崩溃_修复
- 如何使用 Python 合并文件夹内多个 Exce
- Win11怎么开启专注模式_Windows11时钟
- 如何优化Golang程序CPU性能_Golang
- PythonFastAPI项目实战教程_API接口
- Win11怎么设置默认邮件应用_Windows11
- Python高性能计算项目教程_NumPyCyth
- 如何使用Golang log记录不同级别日志_Go
- Django密码修改后会话失效的解决方案
- Win11怎么关闭小组件_Win11禁用任务栏天气
- 如何使用Golang benchmark测量函数延
- 如何使用Golang实现多重错误处理_Golang
- Python函数参数高级用法_默认值与可变参数解析
- 如何将竖排文本文件转换为横排字符串
- VSC怎样在Linux运行PHP_Ubuntu系统
- Windows10电脑怎么设置虚拟内存_Win10
- LINUX怎么进行文本内容搜索_Linux gre
- PyTorch DDP 多进程训练在 Kaggle
- Python抽象类与接口设计_规范说明【指导】
- Win11怎么用设置清理回收站_Win11设置清理
- Windows10系统怎么查看CPU核心数_Win
- Win11怎么压缩文件 Win11自带压缩解压功能
- php本地部署后数据库连接报错_1045acces
- C++如何编写函数模板?(泛型编程入门)
- mac怎么打开终端_MAC终端Terminal使用
- Win10如何更改开机密码_Windows10登录
- php打包exe怎么传递参数_命令行参数接收方法【
- Windows音频驱动无声音原因解析_声卡驱动错误
- Python代码测试策略_质量保障解析【教程】
- Windows家庭版如何开启组策略(gpedit.
- 如何在 Go 结构体中正确初始化 map 字段
- php串口通信波特率怎么选_根据硬件手册设置正确波
- 如何提升Golang程序I/O性能_Golang
- Win11麦克风没声音怎么设置_Win11麦克风权
- Python对象比较与排序_集合使用说明【指导】
- Win11任务栏怎么固定应用 Win11将软件图标
- Windows10电脑怎么连接蓝牙设备_Win10
- Win11怎么查看显卡显存_查询Win11显卡详细
- 如何在Golang中优化文件读写性能_使用缓冲和并
- Python对象生命周期管理_创建销毁说明【指导】
- Windows10系统怎么查看系统版本_Win10
- php订单日志权限怎么设_php订单日志文件权限设
- Mac的“调度中心”与“空间”怎么用_Mac多桌面
- 如何在Golang中编写端到端测试_Golang

QQ客服