天天看點

es6函數的擴充

// 寫法一
function m1({x = 0, y = 0} = {}) {
  return [x, y];
}

// 寫法二
function m2({x, y} = { x: 0, y: 0 }) {
  return [x, y];
}
           

上面兩種寫法都對函數的參數設定了預設值,差別是寫法一函數參數的預設值是空對象,但是設定了對象解構指派的預設值;寫法二函數參數的預設值是一個有具體屬性的對象,但是沒有設定對象解構指派的預設值。

// 函數沒有參數的情況
m1() // [0, 0]
m2() // [0, 0]

// x和y都有值的情況
m1({x: 3, y: 8}) // [3, 8]
m2({x: 3, y: 8}) // [3, 8]

// x有值,y無值的情況
m1({x: 3}) // [3, 0]
m2({x: 3}) // [3, undefined]

// x和y都無值的情況
m1({}) // [0, 0];
m2({}) // [undefined, undefined]

m1({z: 3}) // [0, 0]
m2({z: 3}) // [undefined, undefined]