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)
  
相关推荐
naruto_lnq1 小时前
分布式系统安全通信
开发语言·c++·算法
Mr Xu_1 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠1 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
学嵌入式的小杨同学1 小时前
【Linux 封神之路】信号编程全解析:从信号基础到 MP3 播放器实战(含核心 API 与避坑指南)
java·linux·c语言·开发语言·vscode·vim·ux
sleeppingfrog2 小时前
zebra通过zpl语言实现中文打印(二)
javascript
Re.不晚2 小时前
Java入门17——异常
java·开发语言
精彩极了吧2 小时前
C语言基本语法-自定义类型:结构体&联合体&枚举
c语言·开发语言·枚举·结构体·内存对齐·位段·联合
南极星10053 小时前
蓝桥杯JAVA--启蒙之路(十)class版本 模块
java·开发语言
未来之窗软件服务3 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
baidu_247438613 小时前
Android ViewModel定时任务
android·开发语言·javascript