• ES6解构与默认值的结合使用


    在读源码框架时遇到方法中有这样的形参:{ message = 'ok' } = {}

    有点懵为什么已经赋值了还又赋了一个空对象

    随后我去看了阮一峰老师的 ECMAScript 6 入门才明白。这是参数默认值与解构赋值的默认值结合起来使用

    如下列例子:

    function foo({x, y = 5}:any){
        console.log(x,y)
    }
    foo({})        //输出 undefined 5
    foo({x:1})        // 输出 1 5
    foo({x:1,y:2})  // 输出 1 2
    foo()  //报错 TypeError: Cannot destructure property 'x' of 'undefined' as it is undefined.

    只有当函数foo传入的参数是一个对象时,会解构出x,y。否则会报错!当我们需要使用默认值时,必须传入一个空对象,否则就如同上面一样会报错。

    那么如果想要实现不提供参数的情况下实现默认值,我们把foo函数修改成如下:

    function foo({x,y = 5}:any ={}){
        console.log(x,y)
    }
    foo() // 输出为 undefined 5




  • 相关阅读:
    配置文件管理
    Nacos学习
    dockerCompose学习
    Dockerfile
    vue生命周期
    github使用
    推荐系统
    js笔记17
    js笔记16
    js笔记15
  • 原文地址:https://www.cnblogs.com/baiyifengyun/p/15083010.html
Copyright © 2020-2023  润新知