函数的扩展

2021-02-23 14:31:54 浏览数 (1)

函数的扩展

函数参数的默认值

ES6 允许为函数的参数设置默认值,即直接写在参数定义的后面

参数变量是默认声明的,所以不能用let或const再次声明。

使用参数默认值时,函数不能有同名参数

参数默认值是惰性求值的

参数默认值可以与解构赋值的默认值,结合起来使用

默认值的参数都不是尾参数。这时,无法只省略该参数,而不省略它后面的参数,除非显式输入undefined

如果传入undefined,将触发该参数等于默认值,null则没有这个效果

指定了默认值以后,函数的length属性,将返回没有指定默认值的参数个数

指定了默认值后,length属性将失真

利用参数默认值,可以指定某一个参数不得省略,如果省略就抛出一个错误

rest 参数

ES6 引入 rest 参数(形式为...变量名),用于获取函数的多余参数,这样就不需要使用arguments对象了

rest 参数就不存在这个问题,它就是一个真正的数组,数组特有的方法都可以使用

严格模式

ES2016 做了一点修改,规定只要函数参数使用了默认值、解构赋值、或者扩展运算符,那么函数内部就不能显式设定为严格模式,否则会报错

设定全局性的严格模式,这是合法的

函数包在一个无参数的立即执行函数里面

name 属性

函数的name属性,返回该函数的函数名。

如果将一个匿名函数赋值给一个变量,ES5 的name属性,会返回空字符串,而 ES6 的name属性会返回实际的函数名

如果将一个具名函数赋值给一个变量,则 ES5 和 ES6 的name属性都返回这个具名函数原本的名字

Function构造函数返回的函数实例,name属性的值为anonymous

bind返回的函数,name属性值会加上bound前缀

箭头函数

ES6 允许使用“箭头”(=>)定义函数

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

如果箭头函数的代码块部分多于一条语句,就要使用大括号将它们括起来,并且使用return语句返回

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

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

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

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

箭头函数内部,还可以再使用箭头函数

双冒号运算符

现在有一个提案,提出了“函数绑定”(function bind)运算符,用来取代call、apply、bind调用

函数绑定运算符是并排的两个冒号(::),双冒号左边是一个对象,右边是一个函数

该运算符会自动将左边的对象,作为上下文环境(即this对象),绑定到右边的函数上面

如果双冒号运算符的运算结果,还是一个对象,就可以采用链式写法

尾调用优化

尾调用(Tail Call)是函数式编程的一个重要概念,本身非常简单,一句话就能说清楚,就是指某个函数的最后一步是调用另一个函数

尾调用不一定出现在函数尾部,只要是最后一步操作即可

如果所有函数都是尾调用,那么完全可以做到每次执行时,调用帧只有一项,这将大大节省内存

函数调用自身,称为递归。如果尾调用自身,就称为尾递归

函数参数的尾逗号

ES2017 允许函数的最后一个参数有尾逗号(trailing comma)

0 人点赞