首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js解构赋值如何定义默认值?

在JavaScript中,我们可以在解构赋值语句中定义默认值。这就意味着,如果我们试图解构一个不存在的属性,或者属性值为undefined,那么我们可以为这个属性定义一个默认值。...下面是一些例子来说明如何在解构赋值中定义默认值: 对象解构赋值: const { a = 10, b = 5 } = { a: 3 }; console.log(a); // 3 console.log...但是属性b在我们的对象中并不存在,所以我们使用了默认值5。...解构赋值注意:冒号代表重命名, 等号代表赋值默认值,重命名之后,原变量名称不可访问 const { a:aaa, b:bbb } = { a: 3 }; console.log(a) // a is not...但是第二个元素在我们的数组中并不存在,所以我们使用了默认值5。 这样,当我们在解构对象或数组时,可以确保我们总是得到一个值,即使该值在原始数据结构中并不存在。

18310
您找到你想要的搜索结果了吗?
是的
没有找到

Js解构赋值的应用

函数add的参数是一个 解构表达式,不是 数组,传入数组参数后,被解构为变量 a,b。...函数的参数是一条解构表达式 {x=0,y=0}, =后面的 {} 实际上是参数的默认值。函数的参数可以设置默认值,是ES6的新特性。顺便举个函数默认值的栗子,方便理解上面的栗子。...18 guoguo("郭大剑",39); //传了二个参数,两个参数默认值都不起作用,控制台输出 youname is 郭大剑 youage is 39 需要非常注意的一点,用对象解构表达式作为函数的参数时...如果没有默认值,调用函数时不传参数,会导致解构报错。上面的栗子稍微改一下,去掉默认值看看效果。...函数使用对象解构参数,可以很方便的设置各种默认值,而且参数顺序没有限制,只要可以成功解构即可,用处还是很大的。

5.7K40

重学JS-6-一图掌握解构赋值

思维导图 通过下面的思维导图,我们先对JavaScript的解构赋值有一些基本的了解。 什么是解构赋值 解构赋值是ES6的新语法,作用是将对象或者数组“拆包”到一系列变量中。...数组解构 几个例子,介绍数组解构的用法。...基础用法 涉及的知识点: 等号左边可以是任何内容(变量或者对象的属性) 等号右边可以是任何可迭代对象(数组、Set、Map) 可以用额外的逗号来忽略元素 用等号设置默认值 let user = {};...// 默认值 let [name = "Guest", surname = "Anonymous"] = ["Julius"]; alert(name); // Julius(来自数组的值)...alert(surname); // Anonymous(默认值被使用了) 巧用:交换对象 let guest = "Jane"; let admin = "Pete"; // 让我们来交换变量的值:

2.1K10

JS 函数参数默认值、Arguments 和 Rest parameter

一、ES 5 中函数默认值写法 function total(x, y, z) { if (y === undefined) { y = 2 } if (z === undefined...console.log(total(1, undefined, 100)) // 103 console.log(total(1, 10, 100)) // 111 二、ES 6 中函数默认值写法...console.log(total(1, undefined, 100)) // 103 console.log(total(1, 10, 100)) // 111 参数设置注意事项 有默认值的参数要往后靠...参数的默认值可以是其它参数的运算表达式(如 z = x+y) 三、arguments 获取传入参数的个数 用来表示当前函数传入的参数,作为伪数组输出(可通过 Array.from 转换成数组) 示例...arguments.length } console.log(total(1, 10, 100, 1000)) // 4 通过以上代码可知,arguments 只要传入的参数都计算在内 四、.length 获取函数没有默认值的参数

2.8K30

解构赋值的作用_数组解构赋值

文章目录 概念 数组解构 声明分别赋值 解构默认值 交换变量值 解构函数返回的数组 忽略返回值(或跳过某一项) 赋值数组剩余值给一个变量 嵌套数组解构 字符串解构 对象解构 基础对象解构...赋值给新变量名 解构默认值 赋值给新对象名的同时提供默认值 同时使用数组和对象解构 不完全解构 赋值剩余值给一个对象 嵌套对象解构(可忽略解构) 注意事项 小心使用已声明变量进行解构 函数参数的解构赋值...a, b; // 然后分别赋值 [a, b] = [1, 2]; console.log(a); // 1 console.log(b); // 2 解构默认值 如果解构取出的值是undefined,...a和b均设置了默认值 这种情况下,如果a或b的值是undefined,它将把设置的默认值赋给相应变量(5赋给a,7赋给b) 交换变量值 以往我们进行两个变量的交换,都是使用 //交换ab c = a;...(b); // 5 赋值给新对象名的同时提供默认值 前面提到过我们赋值给新的对象名,这里我们可以给这个新的对象名提供一个默认值,如果没有解构它,就会自动使用默认值 let { a: aa =

3.8K20

解构赋值

解构赋值(★★★) ES6中允许从数组中提取值,按照对应位置,对变量赋值,对象也可以实现解构 数组解构 let [a, b, c] = [1, 2, 3]; console.log(a)//1 console.log...(b)//2 console.log(c)//3 //如果解构不成功,变量的值为undefined 对象解构 let person = { name: 'zhangsan', age: 20 };...person; // myName myAge 属于别名 console.log(myName); // 'zhangsan' console.log(myAge); // 20 ​ 小结 解构赋值就是把数据结构分解...,然后给变量进行赋值 如果结构不成功,变量跟数值个数不匹配的时候,变量的值为undefined 数组解构用中括号包裹,多个变量用逗号隔开,对象解构用花括号包裹,多个变量用逗号隔开 利用解构赋值能够让我们方便的去取对象中的属性跟方法

1.1K20

JS】325- 深度理解ES6中的解构赋值

默认值 使用解构赋值表达式时,如果指定的局部变量名称在对象中不存在,那么这个局部变量会被赋值为 undefined,就像这样: ?...当指定的属性不存在时,可以定义一个默认值,在属性名称后添加一个等号(=)和相应的默认值即可: ? 在这个例子中,为变量 age 设置了默认值 20,为非同名变量 sex 设置了默认值 male。...只有对象 person 上没有该属性或者属性值为 undefined 时该默认值才生效。 嵌套对象的解构赋值 解构嵌套对象仍然与对象字面量的语法相似,可以将对象拆解以获取你想要的信息。...用一张图来解释一下其中的解构过程: ? 默认值 在数组的解构赋值表达式中也可以为数组的任意位置添加默认值,当指定位置的属性不存在或其值为 undefined 时使用默认值: ?...上面代码中,数组 list 只有两个元素,变量 city 没有对应的匹配值,但有一个默认值 BJ,所以最终 city 的输出结果不是 undefined 而是默认值 BJ。

3.8K12

第186天:js深入理解构造函数和原型对象

但在js中不存在类的概念,js不是基于类,而是通过构造函数(constructor)和原型链(propotype chains)实现的。...为了解决构造函数的这个缺点,js提供了prototype属相来解决该问题。   ...propotype属性的作用   js中每个数据类型都是对象,除了null 和 undefined,而每个对象都是继承自一个原型对象,只有null除外,它没有自己的原型对象,最终的Object的原型为null...3.了解了构造器,我们来看下原型prototype   JS中万物都是对象,但是对象也分为:普通对象和函数对象,也就是Object 和 Function.   那么怎么区分普通对象和函数对象呢?...js创建对象的时候都有一个__propo__内置属性,用于指向创建它的函数对象的原型对象prototype。   我们还是来根据eg3的代码来分析原型链   console.log(girl.

68220

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券