Js常用数组处理

数组的遍历 forEach()

js 复制代码
const fruits = ["苹果", "香蕉", "橙子"];

// item 代表当前遍历到的那个元素,index 是索引(可选)
fruits.forEach((item, index) => {
  console.log(`第 ${index} 个元素是:${item}`);
});
/*
第 0 个元素是:苹果
第 1 个元素是:香蕉
第 2 个元素是:橙子
*/
  • 替代 for 循环,代码更简洁。

数组静态方法 Array.isArray ()

核心作用判断一个数据到底是不是数组 。返回 truefalse

为什么需要它? 因为 typeof 运算符判断数组会返回 object,分不清数组和对象,所以必须用 Array.isArray()

js 复制代码
const arr = [1, 2, 3];
const obj = { name: "Jack" };
const num = 123;

console.log(Array.isArray(arr));  // true
console.log(Array.isArray(obj));  // false
console.log(Array.isArray(num));  // false

追加 push ()

核心作用:向数组的末尾添加一个或多个元素。

  • 修改原数组
  • 返回值是新数组的长度。
js 复制代码
const animals = ["猫", "狗"];

// 返回值是新长度 3
const newLength = animals.push("猪"); 

console.log(animals);   // ["猫", "狗", "猪"]
console.log(newLength); // 3

头出 shift ()

核心作用:删除数组的第一个元素。

  • 修改原数组
  • 返回值是被删除的那个元素
  • 如果数组为空,返回 undefined
js 复制代码
const languages = ["JS", "Java", "Go"];

// 返回被删掉的元素 "JS"
const delItem = languages.shift();

console.log(languages);   // ["Java", "Go"]
console.log(delItem);     // "JS"

批量头出 unshift ()

核心作用:向数组的开头添加一个或多个元素。

  • 修改原数组
  • 返回值是新数组的长度。
js 复制代码
const nums = [2, 3];

// 返回新长度 3
const newLength = nums.unshift(1);

console.log(nums);  // [1, 2, 3]

转化字符串 join ()

核心作用:把数组里的所有元素拼接成一个字符串。

  • 不修改原数组,
  • 返回拼接后的字符串。
js 复制代码
const chars = ["小", "程", "序"];

// 不传参默认用逗号连接;传参用指定的字符串连接
console.log(chars.join());    // "小,程,序"
console.log(chars.join(""));  // "小程序"
console.log(chars.join("-")); // "小-程-序"

颠倒数组 reverse ()

核心作用:颠倒数组中元素的顺序。

  • 直接修改原数组,
  • 返回值是颠倒后的数组。
js 复制代码
const arr = [1, 2, 3, 4];

// 返回颠倒后的数组 [4, 3, 2, 1]
const res = arr.reverse();

console.log(arr);   // [4, 3, 2, 1] (原数组已被改变)
console.log(res);   // [4, 3, 2, 1]

寻值 indexOf ()

核心作用:查找某个元素在数组中第一次出现的位置。

  • 返回索引,找不到返回 -1
  • 严格匹配===),类型不同也找不到(比如 1"1" 算不同)。
js 复制代码
const colors = ["红", "黄", "蓝", "黄"];

console.log(colors.indexOf("黄"));  // 1 (只返回第一个匹配的索引)
console.log(colors.indexOf("绿"));  // -1 (找不到)
相关推荐
还是大剑师兰特2 小时前
Vue3 + Element Plus 日期选择器:开始 / 结束时间,结束时间不超过今天
前端·javascript·vue.js
还是大剑师兰特2 小时前
数组中有两个数据,将其变成字符串
开发语言·javascript·vue.js
2301_776508722 小时前
C++中的职责链模式实战
开发语言·c++·算法
Saga Two2 小时前
Vue实现核心原理
前端·javascript·vue.js
技术钱2 小时前
vue3实现时间根据系统时区转换对应的时间
javascript·vue.js
sqyno1sky2 小时前
C++中的空对象模式
开发语言·c++·算法
星轨初途2 小时前
C++ 类和对象(下):初始化列表、static 成员与编译器优化深度剖析
android·开发语言·c++·经验分享·笔记
量子炒饭大师2 小时前
【C++ 入门】Cyber动态义体——【vector容器】vector底层原理是什么?该怎么使用他?一文带你搞定所有问题!!!
开发语言·c++·vector·dubbo
AC赳赳老秦2 小时前
OpenClaw 系统监控实战指南:构建高效的电脑/服务器状态监控与自动告警系统
服务器·开发语言·人工智能·php·ai-native·deepseek·openclaw