• ES6-箭头函数


    目的

    引入箭头函数的目的是更简短的函数写法并且不绑定this,箭头函数的语法比函数表达式更简洁

    使用场景

    箭头函数更适用于那些本来需要匿名的地方

    箭头函数语法

    (1)删掉function关键字加上=>

    (2)没有参数加括号

    (3)一个参数可以选择不加()

    (4)没有或多个参数必须加(),并且参数之间用逗号分割

    (5){}中只有一行语句时,可以省略

    1. let add = function(a, b){
    2. return a + b;
    3. }
    4. 转化为
    5. let add = (a, b) => {
    6. return a + b;
    7. }
    8. 再简写为
    9. let add = (a, b) =>a + b

    (6)加括号的函数体返回对象字面量表达式

    1. const fn=uname=>({uname:uname})
    2. console.log(fn1('pink老师'))

    注意:箭头函数属于表达式函数,因此不存在函数提升

    箭头函数参数

    1.普通函数有arguments动态参数

    2.箭头函数没有arguments动态参数,但是有剩余参数...args

    1. const fn = uname => ({ uname: uname })
    2. console.log(fn1('pink老师'))
    3. const getSum = (...arr) => {
    4. let sum = 0
    5. for (let i = 0; i < arr.length; i++) {
    6. sum += arr[i]
    7. }
    8. return sum
    9. }

    箭头函数this

    在箭头函数出现之前,每一个新函数根据它是被如何调用的来定义这个函数的this值

    this的指向:谁调用这个函数,this就指向谁

    1. console.log(this)//windows
    2. function fn() {
    3. console.log(this)//windows
    4. }
    5. fn()
    6. const obj = {
    7. name: 'andy',
    8. sayHi: function () {
    9. console.log(this)//obj
    10. }
    11. }
    12. obj.sayHi()

    箭头函数不会创建自己的this,它只会从自己的作用域链的上一层沿用this。

    1. const fun = () => {
    2. console.log(this)//window
    3. }
    4. fun()
    5. //对象方法箭头函数this
    6. const ob = {
    7. uname: 'pink老师',
    8. sayHi: () => {
    9. console.log(this);//windows
    10. }
    11. }
    12. ob.sayHi()

    在开发中(使用箭头函数前需要考虑函数中this的值),事件回调函数使用箭头函数时,this为全局的window,因此DOM事件回调函数为了简便,还是不太推荐使用箭头函数

  • 相关阅读:
    长春理工大学计算机考研资料汇总
    基于SpringBoot的二手商品交易平台
    Android service几个问题
    专精特新的申请条件
    DataStructure--Tree
    (Matlab)基于蝙蝠算法实现电力系统经济调度
    技术解密Java Chassis 3超实用的可观测性
    Vue过渡效果组件、组件分发、组件ref使用
    计算机专业毕业设计项目推荐02-个人医疗系统(Java+原生Js+Mysql)
    【MYSQL】索引
  • 原文地址:https://blog.csdn.net/weixin_46479909/article/details/132768501