美文网首页
深入浅出ES6教程『箭头函数』

深入浅出ES6教程『箭头函数』

作者: 苏日俪格 | 来源:发表于2018-06-06 14:25 被阅读81次

☞☞ 个人主页欢迎访问 ☜☜


大家好,本人名叫苏日俪格,大家叫我 (格格) 就好,在上一章节中我们学到了字符串模板的用法,下面我们一起来继续学习箭头函数:

在箭头函数之前,需要看一个例子:

function show(a=1){
    let a = 2;
    console.log(a); // Identifier 'a' has already been declared
}
show();

上面的代码告诉我们函数的参数默认已经被定义了,一经声明,就不能再用let或者const进行声明了,只能用var;这个有点跑题了,算是送大家的一个小tip吧,下面让我们一起来看箭头函数吧:

//普通函数的写法:
function show(){
    return 1;
}
show();
//上面的函数的箭头函数写法:
let show = () => 1;  // 箭头的左边是参数右边是返回值
console.log(show());

如果要想在函数里面写语句的时候,写法是这样的:

let show = (a=1,b=2) => {
    console.log(a,b);  // 1 2
}
show();

箭头函数和普通函数除了写法不同之外,还有三点不同,请看下面的例子:

let json = {
    name: '苏日俪格',
    show: function(){
        setTimeout(function(){
            console.log(this.name); // 控制台什么都没有输出
        },1000);
    }
}
json.show();

这个例子大多都是在vue等框架下开发遇到的问题,因为this指向的是当前的函数,先要让它指向外面的json对象,就还要在外面进行转换,太麻烦,而箭头函数则不同:

let json = {
    name: '苏日俪格',
    show: function(){
        setTimeout(() => {
            console.log(this.name); // 苏日俪格
        },1000);
    }
}
json.show();

综上所述,第一个不同之处就是箭头函数里的this指向的是定义函数所在的对象,而不是运行时所在的对象

小白:那第二个不同之处呢?
格格:第二个就是箭头函数里面不能使用arguments,如果用了就是is not defined

解决办法:就是...扩展运算符(在本章的第五小节)

let show = (...a) => {
    console.log(a);  // [1, 2, 3, 4, 5]
};
show(1,2,3,4,5);

第三个就是箭头函数不能当做构造函数来用

let Show = ()=>{
    this.name = '苏日俪格';
}
let a = new Show();
console.log(a.name);    // Show is not a constructor

关于箭头函数我们都已经了然于心,预知扩展运算符如何,请听下回分解 (^∀^)/~~~

本文的所有内容均是一字一句敲上去的,希望大家阅读完本文可以有所收获,因为能力有限,掌握的知识也是不够全面,欢迎大家提出来一起分享!谢谢O(∩_∩)O~

欢迎来我的GitHub,喜欢的可以star,项目随意fork,支持转载但要下标注,同时恭候:我的博客 Resume

等一下( •́ .̫ •̀ ),我还有最后一句话:
这里虽然没有都市的繁华,
也没有山林的鸟语花香,
只有一片如水的宁静,
古人云:
既来之则安之,
既然来到了这里,
就可以静心休憩你的灵魂,
调养你疲惫的心,
再见...

相关文章

  • ES6箭头函数简介

    @(JS技巧)[ES6|箭头函数] ES6箭头函数(Arrow Functions) ES6可以使用“箭头”(=>...

  • es6全家桶(二)—— 箭头函数

    es6全家桶(二)—— rest参数、箭头函数 箭头函数 ES6 允许使用“箭头”(=>)定义函数。 var f ...

  • es6、js、css、jquery、vue以及程序设计 知识点总

    es6 列举常用的es6特性。 箭头函数this的指向。 eg:箭头函数的特性 箭头函数内部没有construc...

  • 箭头函数

    ES6允许使用“箭头”(==>)定义函数。 箭头函数 等同于

  • 学习 ES 6 箭头函数

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

  • JavaScript箭头函数

    ES6新语法箭头函数 箭头函数是ES6新语法,因为语法简单、可读性好,所以使用的也很多。箭头函数也是匿名函数,区别...

  • 关于ES6箭头this的指向问题

    ES6 允许使用 “ 箭头 ” (=>)定义函数。 箭头函数 填 坑。 this的指向是 向上查找 非箭头函数的...

  • ES6箭头函数(Arrow Functions)

    箭头函数是什么?(What) 箭头函数 (Arrow Functions)也称“胖箭头函数”,是ES6全新的特性。...

  • 2019-01-11

    ES6 箭头函数 箭头函数表示法:()=>console.log('Hello') 箭头函数和普通函数的区别 和普...

  • js学习笔记4(函数)

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

网友评论

      本文标题:深入浅出ES6教程『箭头函数』

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