javascript中的数组如何使用?_学习javascript数组操作方法【教程】

9次阅读

javaScript数组是带整数索引的普通对象Length为最大整数索引加1;includes()比indexOf()更可靠,尤其处理NaN;flat()默认只展平一层,无限展平用flat(Infinity)。

javascript中的数组如何使用?_学习javascript数组操作方法【教程】

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() 不能:

立即学习Java免费学习笔记(深入)”;

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 的根源。

text=ZqhQzanResources