nodejs学习

nodejs中箭头函数

2018-12-06  本文已影响21人  村东头元旦家

   nodejs中或者其他语言中都会有箭头函数,刚刚开始时候还不知道什么意思。所以下面就来讲解一下。其实很简单

ES6中允许使用“=>”定义函数

var f = v=>v;

//等同于

var f = function(v){

       reutrn v;

}

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

var f = ()=>5;

//等同于

var f = function(){ return 5;};

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

//等同于

var sum = function(num1,num2){return num1+num2;};

如果箭头函数有多条语句,可以用括号括起来。并且使用return语句返回。

var sum = (sum1,sum2)=>{return num1+num2;};

由于大括号被解释为代码块,所以如果箭头函数直接返回一个对象,必须在对象外边加上括号,否则会报错。

//报错

let getTempItem = id=>{id:id,name:"temp"};

//不报错

let getTempItem = id=>({id:id,name:"temp"});

如果箭头函数只有一句语句,且不需要返回值,可以采用下面的写法,就不用写大括号了。

let fn = ()=>void doesNotReturn():

箭头函数可以与变量解结构结合使用。

const full = ({first,last})=>first+''+last;

//等同于

function full(person){

    return person.first+''+person.last;

}

箭头函数使得表达更加简洁

const isEven=n=>n%2===0;

const square=n=>n*n;

箭头函数的一个用处就是简化回调函数

// 正常函数写法

[1,2,3].map(function(x){returnx*x;});

// 箭头函数写法

[1,2,3].map(x=>x*x);

另一个例子

// 正常函数写法

varresult=values.sort(function(a,b){returna-b;});

// 箭头函数写法

varresult=values.sort((a,b)=>a-b);

下面是 rest 参数与箭头函数结合的例子。

const numbers=(...nums)=>nums;

numbers(1,2,3,4,5)

// [1,2,3,4,5]

const headAndTail=(head,...tail)=>[head,tail];

headAndTail(1,2,3,4,5)

// [1,[2,3,4,5]]

使用注意点

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

(1)函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。

(2)不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。

(3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替。

(4)不可以使用yield命令,因此箭头函数不能用作 Generator 函数。

上面四点中,第一点尤其值得注意。this对象的指向是可变的,但是在箭头函数中,它是固定的。

function foo(){

    setTimeout(()=>{console.log("id:",this.id);},100);

}

var id = 21;

foo.call({id:42});

//id:42

上一篇下一篇

猜你喜欢

热点阅读