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() 不能:
动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包
立即学习“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))不适用于函数、undefined、Date等,慎用 - 需要条件过滤+展平时,
flatMap()更高效:arr.flatMap(x => x.enabled ? [x.value] : [])
数组方法的行为差异往往藏在规范细节里,比如 forEach() 跳过空位、reduce() 第二次调用时的初始值逻辑、find() 对 NaN 的处理——这些不是边缘情况,而是日常调试中突然出现 undefined 的根源。










