本文作者为 360 奇舞团前端开发工程师

TypeScript 之 Lambda 函数

Lambda 函数 又称箭头函数

箭头函数表达式语法比函数表达式语法更简短,并且没有自己的this,arguments,super或new.target。箭头函数表达式更适用于那些本来需要匿名函数的地方,并且它不能用作构造函数。

ES6版本的TypeScript 提供的箭头函数,是定义匿名函数的简写语法,用于函数表达式,省略了function关键字。箭头函数具有this 关键的语法作用。

箭头函数的作用

  • 当我们不需继续输入功能;
  • 它从词汇上捕捉这个关键字的含义;
  • 它从词汇上抓住了参数的意义。

语法

可以分三部分

  • 参数:函数可以有参数,也可以没有参数
  • 箭头符号:=>
  • 语句:表示函数的指令集

如果用箭头函数表示法,就不需要使用function 关键字。参数在()中传递,函数表达式在{}中。

基础语法
(param1, param2, ..., paramN) => { statements }
(param1, param2, ..., paramN) => expression
//当只有一个参数时,圆括号可以省略,可选的
(singleParam) => { statements }
//省略圆括号
singleParam => { statements }
//没有参数的函数应该写成一对圆括号
() => { statements }

ES6 提供了其它写匿名函数的方式,语法糖。

//sum 是一个箭头函数, a、b 是参数,a、b后面的:number 是参数类型   : number 是返回类型
箭头符号分隔了函数参数和函数体
const sum = (a: number,b: number): number => {
  return a+b;
}
 console.log(sum(20,30))// return 50

当不需要函数体,只返回一个值当时候,可省略return 关键字和外面的花括号。

const fun = () => 'value';
类中箭头函数使用
class Student {
    stucode: number
    stuname: string
    //构造函数  构造Student对象
    constructor (code: number, name: string) {
        this.stucode = code
        this.stuname =name
    }
    studetail = () => {
      console.log('stucode:' + this.stucode + '\nstunam:' + this.stuname )
    }
}

export { Student }

import { Student } from '@/views/Student'

 let stu = new Student(100, 'jorn')
 stu.studetail()
带参数的箭头函数
const fun = (item: number ) => item*2;
//当只有一个参数时候,可以省略参数外面的括号
const fun = item => item*2;
//多个参数传递
const fun = (item: number,item1: number, item2: boolean) => {
let value;
if(item2){
 item++;
 value= item;
}else {
item1 ++;
value = item1;
}
  return  value;
}

箭头函数 不能用作构造器,和new 一起用会抛出错误。也没有prototype 属性。yield 关键字通常不能在箭头函数中使用(除非是嵌套在允许使用的函数内)。因此,箭头函数不能用作函数生成器。

函数体

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

//简写函数 省略 return
var func = x => x+x ;
//常规写法
var func = (x,y) => { return x+y; };
返回对象字面量

记住用 params => {object: literal}这种简单的语法返回对象字面量是行不通的。

// 下面这样行不通
var func =  () => { foo: 1 };

var func = () => { foo: function() {} };

这是因为花括号({})里面的代码被解析位一系列语句(即foo 被认为是一个标签,而非对象字面量的组成部分)。所以,记得用圆括号把对象字面量包起来。

var func = () => ({foo: 1});
换行

箭头函数在参数和箭头之间不能换行。

不可以写成下面的,这样是错误的

var func = ()
=> 1;

但是,可以在‘=>'之后换行

var func = (a,b,c) =>
{
1;
}
箭头函数也可以使用闭包
//标准的闭包函数
function A(){
    var i=0;
    return function b(){
    return (++i);
    };
};

var v =A();
v();//1
v();//2

// 箭头函数体的闭包(i=0 是默认参数)
var Add = (i=0) => { return (() => (++i) )};
var v = Add();
v();//1
v();//2

因为只有一个返回值,return 及括号() 也可以省略
var Add = (i=0) => () => (++i);

- END -