es6-函数,es6函数
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}}
- 注意事项
评论暂时关闭