JS中箭头函数=>的最全用法及详细讲解
创始人
2024-05-31 06:49:13

概述

JS中=>是箭头函数,是ES6标准中新增的一种新的函数。箭头函数表达式的语法比函数表达式更简洁,并且没有自己的this,arguments,super或new.target。箭头函数表达式更适用于那些本来需要匿名函数的地方,并且它不能用作构造函数。
基础语法

(param1, param2, …, paramN) => { statements }
(param1, param2, …, paramN) => expression
//相当于:(param1, param2, …, paramN) =>{ return expression; }
// 当只有一个参数时,圆括号是可选的:
(singleParam) => { statements }
singleParam => {statements }
// 没有参数的函数应该写成一对圆括号:
() => { statements }

简单示例

	x => x * x

即相当于:

	function (x) {return x * x;}

更短的函数示例

	    var elements = ['Hydrogen','Helium','Lithium','Beryllium'];elements.map(function(element) { return element.length; }); // 返回数组:[8, 6, 7, 9]// 上面的普通函数可以改写成如下的箭头函数elements.map((element) => {return element.length;}); // [8, 6, 7, 9]// 当箭头函数只有一个参数时,可以省略参数的圆括号elements.map(element => {return element.length;}); // [8, 6, 7, 9]// 当箭头函数的函数体只有一个 `return` 语句时,可以省略 `return` 关键字和方法体的花括号elements.map(element => element.length); // [8, 6, 7, 9]// 在这个例子中,因为我们只需要 `length` 属性,所以可以使用参数解构// 需要注意的是字符串 `"length"` 是我们想要获得的属性的名称,而 `lengthFooBArX` 则只是个变量名,// 可以替换成任意合法的变量名elements.map(({ "length": lengthFooBArX }) => lengthFooBArX); // [8, 6, 7, 9]

三元运算符示例
箭头函数也可以使用条件(三元)运算符:

    var simple = a => a > 15 ? 15 : a;simple(16); // 15simple(10); // 10let max = (a, b) => a > b ? a : b;

不与new一起使用
箭头函数不能用作构造器,和 new一起用会抛出错误。

    var Foo = () => {};var foo = new Foo(); // TypeError: Foo is not a constructor

没有prototype属性
箭头函数没有prototype属性。

    var Foo = () => {};console.log(Foo.prototype); // undefined

函数体
箭头函数可以有一个“简写体”或常见的“块体”。

在一个简写体中,只需要一个表达式,并附加一个隐式的返回值。在块体中,必须使用明确的return语句。

    var func = x => x * x;                  // 简写函数 省略return(简写体)var func = (x, y) => { return x + y; }; //常规编写 明确的返回值(块体)

箭头函数递归

    var fact = (x) => ( x==0 ?  1 : x*fact(x-1) );fact(5);       // 120

浏览器兼容性

结语
更多关于箭头函数的详细介绍可参看JS最新的参考文档:箭头函数 - JavaScript

相关内容

热门资讯

给空压机换上“中国关节” 本报讯 (记者 苏益纯 通讯员 洪江武) 运行温度降低20℃,设备振动值明显下降,各项指标均优于改造...
敏于监督 速于办案   本报讯(全媒体记者匡雪 通讯员赵元桢)“判决结果出来了,我们追诉的上游供货商、监督立案的下线买家...
实地走访 护“桂”有方   近日,广东省肇庆市高要区检察院检察官来到当地肉桂企业,了解企业经营发展现状,结合办案进行风险提示...
伊拉克称不追究外国石油公司“不... 当地时间3月20日晚,伊拉克石油部消息人士称,伊拉克政府决定对在伊外国石油公司负责开发的所有油田实行...
伊朗总统:无意与伊斯兰国家发生... 来源:新华网新华社德黑兰3月20日电 据伊朗伊斯兰共和国通讯社报道,伊朗总统佩泽希齐扬20日表示,伊...