当前位置: 首页 > 面试题库 >

ES6对象解构默认参数

孔征
2023-03-14
问题内容

我正在尝试找出是否有一种方法可以使用默认参数的对象分解,而不必担心对象被部分定义。考虑以下:

(function test({a, b} = {a: "foo", b: "bar"}) {

  console.log(a + " " + b);

})();

{a: "qux"}例如,当我用调用时,我qux undefined在控制台中看到的是我真正想要的时间qux bar。有没有一种方法可以实现而无需手动检查对象的所有属性?


问题答案:

是。您也可以在解构中使用“默认值”:

(function test({a = "foo", b = "bar"} = {}) {

  console.log(a + " " + b);

})();

这不限于函数参数,而是适用于每个解构表达式。



 类似资料:
  • 主要内容:1.对象解构和默认值,2.分配新的变量名,3.未声明分配,4.对象解构和Rest运算符它类似于数组解构,除了可以从对象中提取属性(或键)及其对应的值,而不是从数组中提取值。 销毁对象时,使用键作为变量的名称。 变量名称必须与对象的属性(或键)名称匹配。 如果不匹配,则它将收到的值。 在对象解构中,通过键而不是位置(或索引)提取值。通过以下示例演示来了解对象分解中的基本分配。 示例-简单分配 运行结果如下: 示例-基本对象销毁分配 运行结果如下: 1.对象解构和默认值 与数组解构一样

  • 问题内容: 有没有办法保留解构函数参数的名称?即,根对象的名称? 在ES5中,我可以这样做(使用继承作为隐喻来说明这一点): 我正在使用同一个对象来保存多个配置参数。某些参数由父类使用,而某些参数由子类使用。 有没有办法用ES6中的结构化函数参数来做到这一点? 还是我需要提取所有选项,以便可以将它们分别传递给? 问题答案: 我本人在太多地方都有“选项”论据。我会选择1行额外的代码。在此示例中不值得

  • 本文向大家介绍ES6基础之默认参数值,包括了ES6基础之默认参数值的使用技巧和注意事项,需要的朋友参考一下 如果调用函数的过程中,定义的参数缺失,此参数变量的值则会是undefined。怎么给缺失的参数赋值默认值,在ES6之前,没有简洁的语法设置缺失参数的默认值,但是我们一般可以这么编写代码解决缺失参数默认值: 这种写法是不是比较麻烦?默认值的设置是不是不够直观?在ES6中,我们可以用更简洁的语法

  • 本文向大家介绍ES6数组与对象的解构赋值详解,包括了ES6数组与对象的解构赋值详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了ES6数组与对象的解构赋值。分享给大家供大家参考,具体如下: 数组的解构赋值 基本用法 ES6允许按照一定的模式,从数组和对象中提取值,对变量进行赋值,这被称之为解构(Destructuring) 本质上,这种写法属于“模式匹配”,只要等号两边的模式相同,左边的

  • 问题内容: 我只是在我的 无状态功能组件 之一中设置默认值时遇到了一个关于React性能的问题。 此组件有其定义,但我不喜欢它,因为是 在最后 的文件,这实际上使得它很难看到的。因此,我们不知道默认属性。因此,我将其直接移至函数声明,并使用ES6默认参数值对其进行了分配。 但是随后我们与一位同事争论说这 是否是一个好主意 。因为这样做似乎很简单,但由于 react无法识别 默认值,因此对性能也可能

  • 问题内容: 当我运行它时,它拒绝“ def a(…”,并用红色突出显示“(”。我不知道为什么。 问题答案: 让我在这里澄清两点: 首先,非默认参数不应跟随默认参数,这意味着您无法在函数中定义。在函数中定义参数的正确顺序为: 位置参数或非默认参数,即 关键字参数或默认参数,即 仅关键字参数,即 var-keyword参数,即 是位置参数 是可选参数 是关键字参数 是列表参数 仅限关键字 是var-k