美文网首页
JavaScript----箭头函数

JavaScript----箭头函数

作者: AuglyXu | 来源:发表于2018-11-15 20:11 被阅读0次
  • ES6开始定义函数可以用箭头的方式,不用像以前一样function
  • 格式: let 函数名称 = (形参列表) => {函数体}

简化代码

  • 注意点:
    • 如果函数体中只有一句代码, 那么{}可以省略
    • 如果函数形参列表中只有一个形参, 那么()可以省略
    • 如果函数体中只有一句代码, 并且是返回值, 那么return可以省略
let say = (name) => {return name}
let say = (name) => return name
let say = name => return name
let say = name => name

修改this

  • ES6之前, 谁调用了这个函数, this就是谁
  • 箭头函数没有this这个概念,箭头函数中的this会继承上一层作用域链,相当于在上一层作用域链var self = this,在箭头函数中用了这个self
  • 场景一: 修改定时器中的this指针的指向
function Person() {
        this.age = 666;
        var self = this;

         setTimeout(function () {
            console.log(this); // window
            console.log(self);
         }, 1000);

        setTimeout(()=>{
            console.log(this); // Person
        }, 1000);
        /*
        1.由于Person构造函数也是一个函数, 所以也会开启一个作用域
        2.由于箭头函数是在Person构造函数的作用域中定义的, 所以数据Person构造函数作用域
        3.箭头函数也是一个函数, 所以也会开启一个作用域
        4.在箭头函数中使用this时, 会从所在的作用域链的上一层继承this

        应用场景:
        1. 让setTimeout/setInterval中的this变为我们想要的this
         */
    }
  • 注意点:
    • 箭头函数没有this,所以箭头函数的this指向不能被call,apply,bind修改
    • 箭头函数不能使用arguments,取代arguments可以用扩展运算符
    function Student() {
        this.age = 666;
        // this.say = function () {
        //     // 谁调用就是谁
        //     // 可以被call/apply/bind方法修改
        //     console.log(this); //student
        // }
        this.say = ()=>{
            // 从上一级的作用域继承
            // 不可以被call/apply/bind方法修改
            // 因为箭头函数自己没有this
            // 因为箭头函数中的this只看定义, 不看调用
            console.log(this);//student
        }
    }
    var stu = new Student();
    stu.say();
    // stu.say.call({name:"lnj"});

    // 注意点:
    // 箭头函数中不能使用arguments
    // function test() {
    //     console.log(arguments);
    // }
    let test = () => {
        console.log(arguments);//报错
    };
    test(1, 3, 5);

相关文章

  • JavaScript----箭头函数

    ES6开始定义函数可以用箭头的方式,不用像以前一样function 格式: let 函数名称 = (形参列表) ...

  • ES6~箭头函数

    什么是箭头函数 单表达式箭头函数 相当于 多表达式箭头函数 箭头函数相当于匿名函数,并且简化了函数定义。箭头函数有...

  • 箭头函数和立即执行函数

    箭头函数 箭头函数和普通函数有什么区别?如果把箭头函数转换为不用箭头函数的形式,如何转换主要是this的差别,箭头...

  • javascript----函数

    函数的定义 function 函数名{函数体;} 函数的调用 在 标签内调用函数名() 在HTML文件中调用通过点...

  • 学习 ES 6 箭头函数

    箭头函数的用法 ES6 允许使用“箭头”(=>)定义函数。 箭头函数的一个用处是简化回调函数。 箭头函数 this...

  • 箭头函数

    箭头函数 箭头函数能让this的指向固定化 分析:1)第一个setInterval()中使用了箭头函数,箭头函数使...

  • TS  笔记this

    this 箭头函数在箭头函数创建的地方获得this;非箭头函数,在调用函数的地方获得this如图

  • 箭头函数和数组

    箭头函数&数组 箭头函数 特点: 没有 this 没有 arguments 没有prototype在箭头函数中使用...

  • 箭头函数

    箭头函数 为什么使用箭头函数

  • 箭头函数中this的指向

    箭头函数在平时开发中用着非常爽,箭头函数有什么特点呢 箭头函数不能够当做构造函数使用 箭头函数没有argument...

网友评论

      本文标题:JavaScript----箭头函数

      本文链接:https://www.haomeiwen.com/subject/eqrufqtx.html