JavaScript 数组方法全解析:从基础到高阶应用

📚 基础操作方法

1. push() / pop()

javascript 复制代码
// 添加元素到数组末尾
let fruits = ['苹果'];
fruits.push('香蕉'); // ['苹果', '香蕉']

// 移除最后一个元素
const last = fruits.pop(); // '香蕉',数组变回 ['苹果']

场景:实现栈结构(后进先出)

2. shift() / unshift()

arduino 复制代码
javascript
// 移除第一个元素
const first = fruits.shift(); // '苹果'

// 添加元素到开头
fruits.unshift('芒果'); // ['芒果']

场景:队列操作(先进先出)

3. splice()

css 复制代码
javascript
const arr = [1, 2, 3, 4];
// 从索引1开始删除1个元素,并插入'a'
arr.splice(1, 1, 'a'); // [1, 'a', 3, 4]

特性

  • 修改原数组
  • 可同时实现删除/插入
    场景:动态修改数组内容

🚀 高阶函数(不修改原数组)

4. map()

ini 复制代码
javascript
const prices = [10, 20, 30];
const discounted = prices.map(price => price * 0.8); // [8, 16, 24]

场景:数据格式转换(如你的合同金额格式化)

5. filter()

ini 复制代码
javascript
const numbers = [12, 5, 8, 130];
const bigNumbers = numbers.filter(n => n > 10); // [12, 130]

场景:表格数据筛选(类似你代码中的权限过滤)

6. reduce()

dart 复制代码
javascript
const total = [1, 2, 3].reduce((sum, num) => sum + num, 0); // 6

进阶用法

ini 复制代码
javascript
// 按属性分组(类似合同数据分类)
const contracts = [
  { type: '采购', amount: 100 },
  { type: '施工', amount: 200 }
];

const group = contracts.reduce((acc, cur) => {
  acc[cur.type] = (acc[cur.type] || 0) + cur.amount;
  return acc;
}, {});
// { 采购: 100, 施工: 200 }

🔍 搜索与排序

7. find() / findIndex()

ini 复制代码
javascript
const users = [
  { id: 1, name: '张三' },
  { id: 2, name: '李四' }
];

const user = users.find(u => u.id === 2); // {id:2, name:'李四'}
const index = users.findIndex(u => u.id === 2); // 1

场景:表格行数据定位(类似你的 handleRowClick)

8. sort()

css 复制代码
javascript
// 数字排序
[3, 1, 4].sort((a, b) => a - b); // [1, 3, 4]

// 对象排序(按合同金额)
listData.value.sort((a, b) => a.contractTotalMoney - b.contractTotalMoney);

注意:会修改原数组


🛠️ 其他实用方法

9. slice()

ini 复制代码
javascript
const arr = [1, 2, 3, 4];
const subArr = arr.slice(1, 3); // [2, 3] 

特性:创建数组副本的常用方式

10. concat()

css 复制代码
javascript
const newArr = [1, 2].concat([3, 4]); // [1,2,3,4]

场景:数组合并(替代扩展运算符)

11. flat()

scss 复制代码
javascript
[1, [2, [3]]].flat(2); // [1, 2, 3]

场景:处理嵌套的API响应数据


💡 使用建议

  1. 链式调用:合理组合方法

    css 复制代码
    javascript
    contracts
      .filter(c => c.amount > 100)
      .map(c => ({ ...c, amount: c.amount * 1.1 }))
      .sort((a, b) => b.amount - a.amount)
  2. 性能优化

    • 避免在循环中嵌套高阶函数
    • 大数据量时优先使用 for 循环
  3. Vue 响应式

    ini 复制代码
    javascript
    // 确保触发视图更新
    listData.value = [...listData.value]; 

总结

方法类型 代表方法 使用场景
数据转换 map、flatMap 金额格式化、数据清洗
数据筛选 filter、find 权限过滤、搜索功能
数据聚合 reduce、some、every 统计合计、表单校验
数组操作 splice、slice 动态增删数据项
结构处理 flat、concat 处理嵌套数据、合并数据集
相关推荐
你才是向阳花24 分钟前
前端限流如何实现,如何防止服务器过载
运维·服务器·前端
站在风口的猪11081 小时前
《前端面试题:BFC(块级格式化上下文)》
前端·css·css3
czliutz3 小时前
NiceGUI 是一个基于 Python 的现代 Web 应用框架
开发语言·前端·python
koooo~5 小时前
【无标题】
前端
Attacking-Coder5 小时前
前端面试宝典---前端水印
前端
姑苏洛言8 小时前
基于微信公众号小程序的课表管理平台设计与实现
前端·后端
烛阴8 小时前
比UUID更快更小更强大!NanoID唯一ID生成神器全解析
前端·javascript·后端
Alice_hhu8 小时前
ResizeObserver 解决 echarts渲染不出来,内容宽度为 0的问题
前端·javascript·echarts
逃逸线LOF9 小时前
CSS之动画(奔跑的熊、两面反转盒子、3D导航栏、旋转木马)
前端·css
萌萌哒草头将军10 小时前
⚡️Vitest 3.2 发布,测试更高效;🚀Nuxt v4 测试版本发布,焕然一新;🚗Vite7 beta 版发布了
前端