es6-函数,es6函数


函数默认值+解构赋值

  • 默认值:给函数参数添加默认值更加简洁。
// ES5 添加默认值
function fun (x, y) {
	y = y || 5;
}
// ES6 添加默认值
function fun (x, y = 5) {

}
优点:
1.带默认值的参数写在最后,可以省略不传。
2.更新版本时,可以将默认值参数去掉。

参数的默认值还可以是变量

function fun (x = 5, y = x) {
	console.log(x, y);
}
fun() // 5, 5

但是要注意避免形成暂时性死区(声明前调用),如下情况就会报错。

function fun(x = y, y = 5) {
	console.log(x, y)
}
fun() // y is not defined
  • 与解构赋值连用
// ES5 写法
function fun (obj) {
	console.log(obj.x, obj.y);
}
// ES6 更加简单易看
function fun({x = 5, y = 4}) {
	console.log(x, y);
}
fun({x: 1}) // 1, 4 

rest参数

rest参数(形式为“ …变量名”),用于获取函数多余参数,代替arguments对象 ,rest参数就是将多个的参数变成一个数组,注意,rest参数只能放在参数的最后一个

// rest参数实现累加
function add(...values) {
	return values.reduce((prev, cur) => {
		return prev + cur;
	}, 0)
}
add(1, 2, 3) // 6
// rest参数实现排序
function sorts (...values) {
	return values.sort((next, prev) => {
		return next - prev
	})
}
sorts(2,5,8,1,3) // [1, 2, 3, 5, 8]

箭头函数

  • 由于大括号被解释为代码块,所以如果箭头函数直接返回 个对象,必须在对象外面加上括号
let fun = (id = 5) => ({id:id})
fun() // {id: 5}
// 等同于
let fun1 = (id = 5) => {return {id: id}}
  • 注意事项
文章最后发布于: 2019-10-24 11:31:00

相关内容

    暂无相关文章