JavaScript es6 语法 map().filter() 链式调用,语法解析 和常见demo

摘要:

map:遍历数组并对每个元素执行回调函数,返回一个新数组

filter:对 map 返回的数组进行过滤,返回满足条件的元素组成的新数组

1.数字数组处理

javascript 复制代码
const numbers = [1, 2, 3, 4, 5];

// 先平方,再筛选偶数
const result = numbers
  .map(num => num * num)  // [1, 4, 9, 16, 25]
  .filter(num => num % 2 === 0);  // [4, 16]

console.log(result); // [4, 16]

2.对象数组转换

javascript 复制代码
const users = [
  { id: 1, name: 'Alice', active: true },
  { id: 2, name: 'Bob', active: false },
  { id: 3, name: 'Charlie', active: true }
];

// 获取所有活跃用户的名称
const activeUserNames = users
  .filter(user => user.active)  // 先过滤活跃用户
  .map(user => user.name);  // 再提取名字

console.log(activeUserNames); // ['Alice', 'Charlie']

3.数据清洗

javascript 复制代码
const data = [' hello ', ' world ', '', '  ', 'good'];

// 去除空白字符并过滤空字符串
const cleanedData = data
  .map(str => str.trim())  // 去除两端空格
  .filter(str => str.length > 0);  // 过滤空字符串

console.log(cleanedData); // ['hello', 'world', 'good']

语法解析

javascript 复制代码
// 传统函数写法
numbers.map(function(num) {
  return num * num;
})

// 箭头函数写法  (复杂函数体需要大括号和 return)
numbers.map((num )=> {  
  return   num * num;
})

//当函数体只有单个表达式时: 可以省略大括号 {} 
//该表达式的结果会自动作为返回值(不需要 return 关键字)
numbers.map((num) => num * num)

//当只有一个参数时,可以省略括号 ()
numbers.map(num => num * num)
  
相关推荐
毕设源码-郭学长11 分钟前
【开题答辩全过程】以 基于python电商商城系统为例,包含答辩的问题和答案
开发语言·python
散峰而望14 分钟前
【算法竞赛】栈和 stack
开发语言·数据结构·c++·算法·leetcode·github·推荐算法
Mr -老鬼15 分钟前
Rust 的优雅和其他语言的不同之处
java·开发语言·rust
网安CILLE17 分钟前
PHP四大输出语句
linux·开发语言·python·web安全·网络安全·系统安全·php
weixin_5316518119 分钟前
Rust 的所有权机制
java·开发语言·rust
江公望23 分钟前
QT/QML qmlRegisterType()函数浅谈
开发语言·qt
foundbug99924 分钟前
MATLAB中实现信号迭代解卷积功能
开发语言·深度学习·matlab
哈__32 分钟前
React Native 鸿蒙跨平台开发:下拉刷新功能
javascript·react native·react.js
没有鸡汤吃不下饭42 分钟前
前端打包出一个项目(文件夹),怎么本地快速启一个服务运行
前端·javascript
雪风飞舞43 分钟前
python根据音频生成柱状图
开发语言·python·音视频