当前位置: 首页 > news >正文

基础04-什么时候不能使用箭头函数

箭头函数的缺点

题目

什么时候不能使用箭头函数?

箭头函数的缺点

没有 arguments

const fn1 = () => {console.log('this', arguments) // 报错,arguments is not defined
}
fn1(100, 200)

无法通过 call apply bind 等改变 this

const fn1 = () => {console.log('this', this) // window
}
fn1.call({ x: 100 })

简写的函数会变得难以阅读

const multiply = (a, b) => b === undefined ? b => a * b : a * b

不适用箭头函数的场景

对象方法

const obj = {name: '双越',getName: () => {return this.name}
}
console.log( obj.getName() )

扩展对象原型(包括构造函数的原型)

const obj = {name: '火龙'
}
obj.__proto__.getName = () => {return this.name
}
console.log( obj.getName() )

构造函数

const Foo = (name, age) => {this.name = namethis.age = age
}
const f = new Foo('火龙', 20) // 报错 Foo is not a constructor

动态上下文中的回调函数

const btn1 = document.getElementById('btn1')
btn1.addEventListener('click', () => {  // console.log(this === window)this.innerHTML = 'clicked'
})

Vue 生命周期和方法

{data() { return { name: '火龙' } },methods: {getName: () => {// 报错 Cannot read properties of undefined (reading 'name')return this.name},// getName() {//     return this.name // 正常// }},mounted: () => {// 报错 Cannot read properties of undefined (reading 'name')console.log('msg', this.name)},// mounted() {//     console.log('msg', this.name) // 正常// }
}

【注意】class 中使用箭头函数则没问题

class Foo {constructor(name, age) {this.name = namethis.age = age}getName = () => {return this.name}
}
const f = new Foo('张三', 20)
console.log('getName', f.getName())

所以,在 React 中可以使用箭头函数

export default class HelloWorld extends React.Component {constructor(props) {super(props)this.state = {name: '双越'}}render() {return <p onClick={this.printName}>hello world</p>}printName = () => {console.log(this.state.name)}
}

答案

箭头函数的缺点

  • arguments 参数
  • 无法改变 this

不适用的场景

  • 对象方法
  • 对象原型
  • 构造函数
  • 动态上下文
  • Vue 生命周期和方法

划重点

  • Vue 组件是一个对象,而 React 组件是一个 class (如果不考虑 Composition API 和 Hooks)

你写出来的代码让所有人都能看懂那才是高级的!受教了!程序员这个职业还是脚踏实地,少出bug,少装逼!

http://www.lryc.cn/news/36455.html

相关文章:

  • 算法小抄5-原地哈希
  • java零基础入门(1)
  • java socket实例
  • 计算机中信息的表示和处理 整数和小数的二进制表示
  • Chapter2.2:线性表的顺序表示
  • 老马闲评数字化「4」做数字化会不会被供应商拿捏住
  • robosuite添加无碰撞的模型
  • JS学习笔记day03
  • 离散数学笔记_第一章:逻辑和证明(3)
  • 软件测试分类知识分享,第三方软件测试机构收费贵不贵?
  • 爬虫(二)解析数据
  • 【C++、C++11】可变参数模板、lambda表达式、包装器
  • 外贸主机测评
  • Meta CTO:Quest 2生命周期或比预期更久
  • Vector - CAPL - 文件处理函数
  • 实力加持!RestCloud完成多方国产化适配,携手共建信创生态
  • Unity 3D GUI教程||OnGUI TextArea 控件||OnGUI ScrollView 控件
  • Leetcode.828 统计子串中的唯一字符
  • Hibernate 相关特性
  • 【研究生学术英语读写教程翻译 中国科学院大学Unit1-Unit8】
  • ListView 控件的使用
  • 域控制器搭建以及成员加入
  • 利用 MLP(多层感知器)和 RBF(径向基函数)神经网络解决的近似和分类示例问题(Matlab代码实现)
  • 进阶C语言——数据的存储【详解】
  • KUKA机器人修改机器人名称和IP地址的具体方法示例
  • 【数据分析师求职面试指南】必备基础知识整理
  • 《开关电源宝典 降压电路(BUCK)的原理与应用》
  • R语言基础(一):注释、变量
  • Java 集合进阶(二)
  • 小孩用什么样的台灯比较好?2023眼科医生青睐的儿童台灯推荐