美文网首页
箭头函数

箭头函数

作者: 领带衬有黄金 | 来源:发表于2019-08-14 10:59 被阅读0次

1.箭头函数

基本语法:
ES6允许使用“箭头”(=>)定义函数

var f = a = > a    类似与python中的lambda函数: 如 ----> f = lambda a : a
//等同于
var f = function(a){
   return a;  
}

如果箭头函数不需要参数或需要多个参数,就使用一个圆括号代表参数部分。

//无形参
var f = () => 5;    如 ----> f = lambda : 5
// 等同于
var f = function () { return 5 };

//多个形参
var sum = (num1, num2) => num1 + num2;   如 ---->f = lambda num1, num2: num1 + num2
// 等同于
var sum = function(num1, num2) {
  return num1 + num2;
};

2.使用箭头函数注意点:

箭头函数有几个使用注意点。

(1)函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。
<script>
    var name = '张三';
    var person = {
        name: '小马哥',
        age: 18,
        fav: function () {
            // 当前的this 对象,在哪里使用,就是哪里的this
            console.log(this);
            console.log(this.name)
        }
    };
    person.fav();

    var person2 = {
        name: '小马哥',
        age: 18,
        fav: () => {
            // 当前this指向了定义时所在的对象(window),在window中定义的,所以this对象是window
            console.log(this, 'bb');
            console.log(this.name, 'aa')
        }
    };
    person2.fav();
</script>
结果对比
function foo() {
        setTimeout(() => {
            console.log('id:', this.id);
        }, 1000);
    }

    var id = 21;

    foo.call({id: 42}); # 该箭头函数是在foo中经过替换定义的
    foo()  # 该箭头函数的this是在window中定义的

结果为:
id: 42
id: 21

说明:
上面代码中,setTimeout的参数是一个箭头函数,这个箭头函数的定义生效是在foo函数生成时,而它的真正执行要等到 1000毫秒后。
如果是普通函数,执行时this应该指向全局对象window,这时应该输出21。但是,箭头函数导致this总是指向函数定义生效时所在的对象
(本例是{id: 42}),所以输出的是42。
不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替。
var person3 = {
        name: '小马哥',
        age: 18,
        fav: (...rest) => {
            console.log(rest);
        }
    };

    person3.fav('把妹', '把爷', {'a': 'a'});
说明: ...rest 接收不定长参数,并且只能放在参数的最后一位

相关文章

  • ES6~箭头函数

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

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

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

  • 学习 ES 6 箭头函数

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

  • 箭头函数

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

  • TS  笔记this

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

  • 箭头函数和数组

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

  • 箭头函数

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

  • 箭头函数中this的指向

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

  • js学习笔记4(函数)

    1.箭头函数 ES6新增属性。箭头函数特别适合嵌入函数的场景。 箭头函数虽然语法简介,但是很多场合不适用。箭头函数...

  • js理解普通函数和箭头函数

    普通函数: 箭头函数: 区别: 构造函数和原型 箭头函数不能作为构造函数 不能new。会报错 箭头函数没有原型属性...

网友评论

      本文标题:箭头函数

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