前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ES6基础语法之变量解构赋值(对象)

ES6基础语法之变量解构赋值(对象)

作者头像
十月梦想
发布2018-08-29 11:50:24
5720
发布2018-08-29 11:50:24
举报
文章被收录于专栏:十月梦想十月梦想

昨天简单看了并且了解了数组的解构赋值,今天进一步看一下对象的解构赋值,并逐渐深入看一些复杂的对象结构赋值是怎么样子的!!!

先来看一个简单的对象,我们进行解构!

代码语言:javascript
复制
    let obj = {
		a: 1,
		b: 2
	} 
	//解构对象中的变量
	let  {a,b}=obj;
	console.log("a="+a+"  "+"b="+b);//打印出结果a=1,b=2	

上述是一个简单的对象解构变量实例,下面进一步看一些结构对象中变量的拓展,当结构不存在的变量会是怎么样的情形呢?

代码语言:javascript
复制
    let obj = {
		a: 1,
		b: 2
	} 
//不存在的对象提示undefined
		let { c, b } = obj
		console.log("c:" + c); //由于对象中不存在c,返回undefined

如果想将对象中的变量重命名该如何操作?

代码语言:javascript
复制
 let obj = {
		a: 1,
		b: 2
	}
	//获取到a或者b重命名在ES5下应该是这样的
	var A=obj.a;//将对象中a重新赋值给A
	//在ES6解构中就是很简单了
	let {a:A,b}=obj;//这样A=obj中的a了,冒号表示重新赋值给后面的变量名
	//那么原来的表示什么呢
	let {a,b}=obj 相当于 a=obj.a   b=obj.b了在对应的对象中找到相应的去赋值	

对应已经存在的变量如何进行解构赋值呢?

代码语言:javascript
复制
let obj = {
			a: 1,
			b: 2
		}
	let a = 0;
	console.log("a:" + a);
	//	{a,b}=obj;重新赋值提示语法错误,表示变量a已经存在,这个不是一个代码块,只是语法解构
	//但是被默认当做代码块
	({a,b}=obj);//外加括号包围,表示这是一个语法解构就ok	

看一下较为复杂的对象解构化.

代码语言:javascript
复制
	//声明一个复杂的对象
	let obj={
		arr:[
		'Y.o',
		{
			a:1,
			b:2,
			c:3
		},
		]
	}
	let {arr:[str,{a,b,c}]}=obj;

再看一个更为复杂的对象,进行解构

代码语言:javascript
复制
		let sts={
			name:"小米",
			test:"期末考试",
			add:['河南省','北京','上海','天津','云南','贵州'],
			days:{
				desc:"这是一天",
				time:"00:00",
				sort:['上午','中午','下午']
				
			}
		}
       let {name,test,add:[a,b,c,d],days:{dc,time,sort:[top,mid,bot]}}=sts;

总结:对于嵌套的对象(对象的中变量又是一个对象),解构的时候加冒号使用基础的{}进行嵌套结构,嵌套的如果是数组就嵌套解构数组(使用中括号)的方式嵌套结构.一般遇到的数据不会这么复杂的,对象的结构赋值大概就这样,如有问题请留言谢谢!

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-6-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档