js箭头函数

2021-09-26 10:17:53 浏览数 (1)

箭头函数

箭头函数表达式没有自己的this,arguments,super或new.target。

引入箭头函数作用

引入箭头函数的作用:更简短的函数并且不绑定this

更简短的函数

代码语言:javascript复制
let sum = (x,y,z) => { return x y z; }

不绑定this

在箭头函数出现之前,每个新定义的函数都有他自己的this值。(在构造函数的情况下是一个新对象,在严格模式的函数调用中为 undefined,如果该函数被作为“对象方法”调用则为基础对象等)。

通过call、apply调用箭头函数

由于箭头函数没有自己的this指针,通过call()、apply()方法调用时,第一个参数会被忽略。(箭头函数中若用了this,这个this指向包裹箭头函数的第一个普通函数的 this。)

不绑定arguments

大多数情况下,使用剩余参数是相较于arguments对象的更好选择。

箭头函数不能使用new操作符

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

代码语言:javascript复制
var Foo = () => {};
var foo = new Foo(); // TypeError: Foo is not a constructor

箭头函数没有prototype属性

箭头函数不能用作生成器

yield 关键字通常不能在箭头函数中使用(除非是嵌套在允许使用的函数内)。因此,箭头函数不能用作生成器。

返回对象字面量时

箭头函数返回简单值时可以简写成:

代码语言:javascript复制
let sum = ( x, y ) => x   y

but返回对象字面量时不口以这样var func = () => {foo: 1},需要用圆括号括起来

代码语言:javascript复制
var func = () => ({foo: 1});

以下跟箭头函数没啥关系咯~~

函数的默认参数

没有默认参数时要进行检查检查~

代码语言:javascript复制
function multiply(a, b) {
  b = (typeof b !== 'undefined') ?  b : 1;
  return a * b;
}

有了默认参数后~优雅的写代码

代码语言:javascript复制
function multiply(a, b = 1) {
  return a * b;
}

0 人点赞