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

相关内容

热门资讯

金帝股份跌0.69%,成交额3... 12月2日,金帝股份跌0.69%,成交额3212.79万元,换手率1.85%,总市值53.62亿元。...
泰鸿万立跌0.76%,成交额1... 12月2日,泰鸿万立跌0.76%,成交额1773.07万元,换手率1.20%,总市值66.89亿元。...
新相微跌0.94%,成交额1.... 12月2日,新相微跌0.94%,成交额1.35亿元,换手率2.10%,总市值92.23亿元。异动分析...
美信科技涨0.31%,成交额4... 12月2日,美信科技涨0.31%,成交额4552.86万元,换手率4.12%,总市值26.47亿元。...
宏工科技跌1.77%,成交额2... 12月2日,宏工科技跌1.77%,成交额2.04亿元,换手率9.67%,总市值101.06亿元。异动...