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] 都是 undefinedlength 也会自动设为 6。

  • 这种写法会创建稀疏数组(sparse array),for...offorEach() 会跳过空位,但 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)) 不适用于函数、undefinedDate 等,慎用
  • 需要条件过滤+展平时,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; ?>

相关推荐

在线咨询

点击这里给我发消息QQ客服

在线咨询

免费通话

24h咨询:4006964355


如您有问题,可以咨询我们的24H咨询电话!

免费通话

微信扫一扫

微信联系
返回顶部