JavaScript中的箭头函数以及编写优化

箭头函数

1.1.1 箭头函数的概念

箭头函数时ES 6之后增加一种编写函数的方法,并且它比函数的表达式要更加简洁

  • 箭头函数不会绑定this,arguments属性
  • 箭头函数不能作为构造函数来使用(不能和new一起来使用,会出现错误)
js 复制代码
  //1.之前的方式
  function foo1() {
    var foo2 = function() {}
  }
  
  //2.箭头函数的完整写法
  //把function去掉,然后加个=>
  var foo3 = (name,age)=> {
    console.log("箭头函数的函数体")
    console.log(name,age)
  }

1.1.2 箭头函数的编写优化

  1. 优化一:如果只有一个参数()可以省略
js 复制代码
  //1.优化一:如果箭头函数只有一个参数,那么()可以省略
  var names = ["abc","cba","nba"]
  names.forEach(item=>[
    console.log(item)
  ])
  1. 优化二:如果函数执行体只有一行代码,那么可以省略大括号

并且这行代码的返回值会作为整个函数的返回值

  1. 优化三:只有一行代码时,这行代码的表达式结果会作为函数的返回值默认返回的
js 复制代码
// //一行代码中不能带有return关键字,如果省略,需要带return一起省略(下一条规则)
names.forEach(item =>console.log(item))
var newNums =nums.filter(item=>{
  return item % 2 ===0
 })
  1. 优化四:如果默认返回值是一个对象,那么这个对象必须加()
js 复制代码
 var arrFn = ()=>({name:"why"})//可能会被当成执行体,要加小括号
 console.log(arrFn())

综合案例

js 复制代码
//箭头函数实现nums所有偶数平方的和
var nums = [20,30,11,15,111]
var result = nums.filter(item=>item % 2 === 0)
                  .map(item => item*item)
                  .reduce((prevValue,item)=>prevValue+item)
                  console.log(result)
相关推荐
天才熊猫君几秒前
配置与数据分离:一种可视化搭建的属性编辑方案
前端·javascript
林希_Rachel_傻希希11 分钟前
web性能之相关路径——AI总结
前端·javascript·面试
不好听61314 分钟前
从零搭建一个 RAG 语义搜索系统 —— DEMO的初始阶段
javascript·面试·llm
何时梦醒17 分钟前
上下文工程(Context Engineering):AI 应用开发的新范式 —— 从理论到实战全解析
javascript
竹林81818 分钟前
用 wagmi v2 踩坑两天,我终于搞懂了多链钱包切换在 DeFi 前端中的正确姿势
前端·javascript
用户21366100357221 分钟前
Vue项目搜索功能与面包屑导航
前端·javascript
星栈25 分钟前
LiveView 的实时通信,爽是爽,但 PubSub 和广播也最容易把自己绕晕
前端·前端框架·elixir
用户29307509766926 分钟前
告别关键词匹配,拥抱向量语义 —— RAG 搜索从零到一
前端
独孤留白35 分钟前
从C到Rust:告别 C 的"指针 + 长度"手动模式
前端·rust
阿黎梨梨1 小时前
揭秘大语言模型的底层逻辑:从文本分词到高维向量的计算之旅
javascript·人工智能