JavaScript编程精解系列——JavaScript 箭头函数
小作 2018-03-07 来源 :网络 阅读 1035 评论 0

摘要:本系列JavaScript编程精解将给大家系统的讲解一些基础知识,看完这系列文章会让你对JavaScript入门有更加清晰的概念。

本系列JavaScript编程精解将给大家系统的讲解一些基础知识,看完这系列文章会让你对JavaScript入门有更加清晰的概念。

 

JavaScript箭头函数是ECMAScript 6中引入的编写函数表达式的一种简便方法。通常,在JavaScript中,可以通过两种方式创建函数:

 

函数语句。

函数表达式。

可以如下所示创建函数语句:

 

function add(num1, num2) {

    var res = num1 + num2;

    return res;

}

var sum = add(7, 2);

console.log(sum);

也可以创建相同功能的函数表达式,如下所示:

 

var add = function (num1, num2) {

    var res = num1 + num2;

    return res;

}

var sum = add(7, 2);

console.log(sum);

ECMA 2015(或ECMA Script 6)引入了更短的语法来编写函数表达式,称为箭头函数。使用箭头函数,你可以将上面的函数表达式编写为:

 

var add = (num1, num2) => { return num1 + num2; };

正如你所看到的,使用箭头函数编写的函数表达式更短。

 

箭头函数的基本语法规则

 

首先,参数应该在小括号中传递。你可以创建有两个参数的箭头函数,如下所示:

 

ar add = (num1, num2) => { return num1 + num2; };

如果只要传递一个参数,那么括号是可选的,可以选择忽略。你可以创建一个参数的箭头函数,如下所示:

 

var add = num => { return num * 10; };

如果没有参数,那么你必须要有一个空括号——不能没有。所以对于没有参数的函数,箭头函数是这样写的:

 

var add = () => { console.log("hey foo") };

如果函数中有单个表达式或语句:

 

在主体中使用括号是可选的。

使用return语句是可选的。

你可以重写add函数,而不使用函数体中的括号和return语句,如下所示:

 

var add = (num1, num2) => num1 + num2;

你也可以使用控制台语句编写不带参数的函数,如下所示:

 

var add = () => console.log("hey");

返回对象字面量

 

JavaScript箭头函数也可以返回对象字面量。唯一的要求是你需要把返回对象装入小括号中,如下所示:

 

var foo = (name, age) => ({

    name: name,

    age: age

})

var r = foo("my cat", 22);

console.log(r);

正如你所看到的那样,要返回的对象被放在了小括号内。如果你不这样做,那么JavaScript将无法区分对象字面量和函数体。

 

箭头函数支持rest参数

 

JavaScript箭头函数支持另一个ES6功能:rest参数。你可以在箭头函数中使用rest参数,如下面的代码所示:

 

var add = (num1, num2, ...restparam) => {

    console.log(restparam.length);

    var result = num1 + num2;

    return result;

}

var r = add(67, 8, 90, 23);

console.log(r);

在这个例子中,当你使用带有rest参数的箭头函数时,输出会是2和75,因为传递的额外参数的数量是2,num1和num2的总和是75。

 

箭头功能支持默认参数

 

另外,JavaScript箭头函数还支持另一个ES6功能:默认参数。此处详细介绍了默认参数。你可以在箭头函数中使用默认参数,如下所示:

 

var add = (num1 = 9, num2 = 8) => {

    var result = num1 + num2;

    return result;

}

var r = add();

console.log(r);

在上面的代码中,箭头函数中有默认参数。调用该函数时,我们没有传递任何值,并且由于默认参数的存在,输出将是17。

 

“this”在箭头函数中如何工作?

 

箭头函数没有它自己的this值。箭头函数中的this值总是从封闭范围继承。在JavaScript中,每个函数都有它自己的this值,这取决于代码是如何调用函数的。请仔细看下面列出的代码:

 

var Cat = {

    name: 'mew',

    canRun: function () {

        console.log(this)

        var foo = () => { console.log(this) }

        foo();

    }

};

在这里,cat是一个对象字面量,它包括:

 

使用object.method在方法中获取一个有意义的对象作为this值。

对于任何其他要求,使用箭头函数,由于函数没有自己的this值,所以它将继承封闭范围的this值。

使用箭头函数的限制条件

 

应用箭头函数时要注意的一些限制条件:

 

箭头函数没有参数对象。

箭头函数不能与新运算符一起使用,因此它不能用作构造函数。

箭头函数没有原型属性。

如果你尝试使用箭头函数作为构造函数,那么你会得到异常。请看下面的代码:

 

var foo = (name, age) => { name = name, age = age };

var f1 = new foo("cat", 6);

而且,当你试图输出箭头函数的原型值时,你会得到undefined的输出:

 

var foo = (name, age) => { name = name, age = age };

console.log(foo.prototype);

发生这种情况的原因是因为箭头函数没有原型属性。请记住:虽然箭头函数为你提供了编写函数表达式的简短方法,但它没有自己的this值,也不能用作构造函数。

 

希望这篇文章可以帮助到你。总之,同学们,你想要的职坐标IT频道都能找到!

本文由 @小作 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved