【es6】函数参数设置默认值

1、es6之前的函数参数默认值写法

1.1、使用短路或||的写法

  • 当y为空时,y判断为false ,走||右边的,所以y = 'world';
  • 当y不为空时,y判断为true,不需要再运行||右边的,所以 y = y
javascript 复制代码
function log(x, y) {
  y = y || 'World';
  console.log(x, y);
}

log('Hello') // Hello World
log('Hello', 'China') // Hello China
log('Hello', '') // Hello World

这中写法有个问题,就是第三种输出中的结果。当y值设置为""时,走短路与运算判断为false,从而将默认值赋予了y。但是原本的意思是y的值就是"",从而希望输出的是 Hello

1.2 添加typeof 判断是否为undefined

javascript 复制代码
function log(x, y) {
  if (typeof y === 'undefined') {
  		y = 'World';
	}
  console.log(x, y);
}

log('Hello') // Hello World
log('Hello', 'China') // Hello China
log('Hello', '') // Hello 

这种写法可以避免1.1中y值为空串的情况。

2、es6写法

javascript 复制代码
function log(x, y = 'World') {
  console.log(x, y);
}

log('Hello') // Hello World
log('Hello', 'China') // Hello China
log('Hello', '') // Hello

上面是es6的写法,简单方便。

下面是解构赋值和函数默认值结合:

方法一是个解构变量设置默认值,二默认值生效的条件是对象属性值严格等于undefined。

方法二是设置对象的值,没有设置解构变量的默认值。

在没有参数和x y都有值的情况下,两者的结果一样。其他情况下两者有区别。

javascript 复制代码
// 写法一
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]
相关推荐
LEAFF3 分钟前
如何 测试Labview是否返回数据 ?
前端
Spider_Man5 分钟前
🚀 从阻塞到丝滑:React中DeepSeek LLM流式输出的实现秘籍
前端·react.js·llm
心在飞扬7 分钟前
理解JS事件环(Event Loop)
前端·javascript
敲代码的玉米C10 分钟前
深入理解链表反转:从基础到进阶的完整指南
javascript
盏茶作酒2923 分钟前
打造自己的组件库(一)宏函数解析
前端·vue.js
山有木兮木有枝_43 分钟前
JavaScript 设计模式--单例模式
前端·javascript·代码规范
一大树1 小时前
Vue3 开发必备:20 个实用技巧
前端·vue.js
颜渊呐1 小时前
uniapp中APPwebview与网页的双向通信
前端·uni-app
10年前端老司机1 小时前
React 受控组件和非受控组件区别和使用场景
前端·javascript·react.js
夏晚星1 小时前
vue实现微信聊天emoji表情
前端·javascript