在ES5与ES6环境下处理函数默认参数

作者: 十___ | 来源:发表于2018-05-14 00:48 被阅读0次
函数默认值是一个很提高鲁棒性的东西 让程序更健壮。
MDN关于函数默认参数的描述:函数默认参数允许在没有值或undefined被传入时使用默认形参。
  • ES5

使用逻辑或 | | 来实现

在ES5版本中,并没有提供之间方法供给我们处理函数默认值
所以只能够自己去增强函数的功能,一般会这么做:

function doSomething(name, age) {
    name = name || 'default name';
    age = age || 18;
    console.log(name, age);
}

我们将函数的两个参数name与age进行默认值的处理,如果没有则使用默认值。
在执行一下函数后,好像没什么不对:

doSomething();          //14 default name 18
doSomething('男嘉宾');   //男嘉宾 18
doSomething(null, 23);   //default name 23

而当我们执行这样的代码时,就会获得一些超出预料的结果:

doSomething('男嘉宾', 0)//男嘉宾 18

对于参数0,我们上边的默认参数实现方法是有问题的
就像下边的四个表达式,都会输出12,这显然不能够满足上边MDN函数默认参数的定义:

console.log(0 || 12);
console.log('' || 12);
console.log(null || 12);
console.log(false || 12);

正确姿势

ES5中正确的默认值处理应该是这样:

function doSomething(name, age) {
    if(name === undefined) {
        name = 'default name';
    };
    if(age === undefined) {
        age = 18;
    };
    console.log(name, age)
}

或者简写成三目运算符形式:

function doSomething(name, age) {
    name = name === undefined ? 'default name' : name;
    age = age === undefined ? 18 : age;
    console.log(name, age)
}

这些操作
未免太麻烦,所以,我们对这个逻辑进行一个简单的封装:

function doSomething(name, age) {
    name = defaultVa lue(name,
        'default name')
    age = defaultValue(age, 18)
    console.log(name, age)
}

这样就很简洁的在ES5实现了函数默认参数的逻辑
关于上边的defaultValue函数实现方法,可以使用这种方式来省去三元运算符的操作:

function defaultValue() {
    return arguments[+(arguments[0] === undefined)]
}

arguments表示函数所有的实参
我们使用arguments[0]获取第一个实参,然后与undefined进行全等比较
在外层将表达式的结果转换为Number,然后将这个值作为下标获取arguments中对应的参数。
因为是由布尔值转变而来,所以只会存在0、1两种选项。
也就实现了上边三元运算符的功能。


ES6

ES6版本的函数默认值基本上就是我们上边实现的那种套路了
但是因为是原生的,所以会有相应的新语法,能够更简洁的使用:

function doSomething(name = 'default name ', age = 18) {
    console.log(name, age)
}

ES6中提供了新的语法,可以让我们在函数声明参数后边直接写= [defaultValue]的这种形式来设置某个参数的默认值。
直接使用这种方式,省去了在函数内部进行默认值的检查,能够让函数专注的做它应该做的事情。


如何针对某些必填参数抛出异常

ES6这种新语法能够让我们很好的针对某个必填参数进行错误提醒:

function requireParams() {
    throw new Error('required params')
}

function doSomething(name = requireParams(), age = 18) {
    // do something
}

如果name参数为undefned,就会触发默认值规则
然后调用requireParams函数,而我们在函数中直接throw了
一个Error


复杂结构参数的默认值处理

上边的处理都是针对简单的基本类型数据进行处理的,但如
果我们有如下的一个函数:

function init({id,value}) {}

init({
    id: 'tagId'
    value: 1
})

如果在ES5环境下,针对这种参数的默认值处理将会变得无比复杂
首先要判断这一个参数是否存在,然后在判断参数中的所有key是否存在
而在ES6中,可以这样来做:

function init({
    id = 'defaultId';
    value = 1;
} = {}) {
    console.log(id, value);
}

首先在解构函数的后边添加默认值= {}, 然后针对每一项参数添加默认值,很简洁的就实现了我们的需求。

相关文章

  • ES6 写法示例

    匿名函数调用 ES5 ES6 箭头函数 将数组的内容 * 2 ES5 ES6 默认参数 ES5 ES6 不定参数 ...

  • ES6学习-3.函数

    1、函数形参的默认值 在ES5中函数定义了参数,如果要设置默认值,则需要在函数内进行判断处理,例如: 而在ES6中...

  • 二、函数

    ES2015 二、函数 1、带参数默认值的函数 在ES5中模拟参数默认值 ES6中的参数默认值   在本例中,只有...

  • ES6最棒的新特性

    ES6中的默认参数 ES5的写法 在ES6中,我们可以把默认值直接放进函数签名 ES6中的模板表达式 ES5的写法...

  • 2019-02-22 ES6常用新特性

    默认参数 ES5中不能直接为函数的参数指定默认值,只能通过以下方式: es6可以直接把默认值放在函数申明里 函数的...

  • 4.参数默认值&&不确定参数&&箭头函数

    参数默认值 // 不确定参数的问题 es5 arguments es6ES5 ES6 ES6 中的箭头函数 (...

  • ES6 Function类型

    相比ES5,ES6 允许为函数的参数设置默认值。 即直接写在参数定义的后面。 ES6 引入 rest 参数(形式为...

  • ES6之函数

    带默认参数的函数 在 ES5 或更早的版本中,你可能会使用下述模式来创建带有参数默认值的函数: ES6 能更容易地...

  • ES6参数默认值

    参数默认值 首先,来看一下es5中的函数默认值 es6中提供了一个新的函数默认值的方式,外界传入的参数会依次赋值给...

  • es6中函数新增特性

    带有参数默认值的函数 在es5中,对于参数进行默认值,需要进行判断赋值。 在es6可以对于没有传值的参数可以赋予默...

网友评论

    本文标题:在ES5与ES6环境下处理函数默认参数

    本文链接:https://www.haomeiwen.com/subject/fobrdftx.html