• 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事件回调函数为了简便,还是不太推荐使用箭头函数

  • 相关阅读:
    C#中的委托、事件与接口
    vscode插件Open in External App windows下使用typora打开md文件
    tensorRT简明使用
    Java中long(Long)与int(Integer)之间的转换
    java毕业设计论文题目SSM框架车库停车计费系统|停车场
    关于我在编程里学表白这件事。。。。【python表白代码】
    代码随想录第二天
    数据库
    react setupProxy.js导致项目无法启动
    Java面试_并发编程_线程基础
  • 原文地址:https://blog.csdn.net/weixin_46479909/article/details/132768501