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)
  
相关推荐
@Turbo@1 分钟前
【QT】在QT6中读取文件的方法
开发语言·数据库·qt
_extraordinary_13 分钟前
Java 异常
java·开发语言
moz与京15 分钟前
【数据结构】字符串操作整理(C++)
开发语言·数据结构·c++
招财进宝。。17 分钟前
c# 获取电脑 分辨率 及 DPI 设置
开发语言·c#·电脑
无处不在的海贼20 分钟前
小明的Java面试奇遇之:支付平台高并发交易系统设计与优化[特殊字符]
java·开发语言·面试
居居飒25 分钟前
深入理解 JDK、JRE 和 JVM 的区别
java·开发语言·jvm
江城开朗的豌豆28 分钟前
JavaScript篇:构造函数 vs Class:谁才是对象创建的王者?
前端·javascript·面试
江城开朗的豌豆31 分钟前
JavaScript篇:数组找不同:如何快速找出两个数组间的'单身狗'元素?
前端·javascript·面试
几道之旅32 分钟前
python-pptx去除形状默认的阴影
开发语言·javascript·python
1560820721942 分钟前
在QT环境下部署FFT库
开发语言·qt