一、 属性的简洁表示法
ES6允许直接写入变量和函数作为对象的属性和方法。意思就是说允许在对象中只写属性名,不用写属性值。这时,属性值等于属性名称所代表的变量。下面分别举一个例子来说明:
属性:
function getPoint(){ var x = 1 ; var y = 2; return {x,y} }
等同于
fucntion getPoint(x,y){ var x = 1 ; var y = 2; return {x:x,y:y} }
测试:
getPoint();//{x:1,y:10}
函数:
var obj = { fun(){ return "simply function"; } };
等同于
var obj = { fun: function(){ return "simply function"; } }
测试:
obj.fun();//simply function
二、属性名表达式
ES6里允许定义对象的时候用表达式作为对象的属性名或者方法名,即把表达式放在方括号里。
属性
let propKey = 'foo'; let obj = { [propKey] : true, ['a'+'bc'] : 123 }
测试:
obj.foo; //true obj.abc ; //123
方法
let obj = { ['h'+'ello'](){ return "hello world"; } }
测试:
obj.hello();//hello world
注意:
属性名表达式与简介表达式不能同时使用。
//错误的 var foo = 'bar'; var bar = 'abc'; var baz = { [foo] }; //正确 var foo = 'bar'; var baz = { [foo] : 'abc'}
三、方法的name属性
这个比较容易理解,直接阐述文字。
函数的name属性返回函数名。对象方法也是函数,因此也有函数名。
四、Oject.is()
Object.is()用来比较两个值yan'ge严格相等。与严格比价运算符(===)的行为基本一致。不同之处只有两个:一是 +0 不等于 -0 ,二是NaN等于自身
+0 === -0 //true NaN === NaN //false Object.is(+0,-0);//false Object.is(NaN,NaN);//true
五、Oject.assign()
Object.assign()方法是用于将源对象的可枚举属性复制到目标对象。它至少需要两个参数,第一是目标对象,后面的全是源对象。
注意:
demo:
var target = {a:1,b:2}; var source1 = {a:2,c:5}; var source2 = {a:3,d:6}; Object.assign(target,source1,source2); target//{a:3,b:2,c:5,d:6}
Object.assign可用于处理数组,但是会将其视为对象
Object.assign([1,2,3],[4,5]); //[4,5,3]
其他用处
六、属性的可枚举性
对象的没个属性都有一个描述对象(Descriptor),可通过Object.getOwnPropertyDescriptor(object,prop) ,object表示对象,prop表示对象的里的一个属性,用的时候需要加上引号。描述对象里面有个enumerable(可枚举性)属性,来描述该属性是否可枚举。
ES5中会忽略enumerable为false的属性
ES6新增的操作
7. 属性的遍历
ES6中一共有6种方法可以遍历对象的属性。
以上6种方法遍历对象的属性遵守同样的属性遍历次序规则
Reflect.ownkeys({[Symbol()]:0,b:0,10:0,2:0,a:0}) //[‘2','10','b','a',Symbol()]
八、 proto 属性,Object.setPrototypeOf(),Object.getPrototypeOf()
proto 属性
(前后应该有两个下划线,这里没显示出来)。用来读取或者设置当前对象的prototype对象。但是一般不直接对这个属性进行操作,而是通过Object.setProtortypeOf() (写操作)、Object.getPrototypeOf() (读操作)或者Object.create() (生成操作)代替。
Object.setProtortypeOf()
let proto = {}; let obj = { x : 10}; Object.setProtortypeOf(obj,proto); proto.y = 20; proto.z = 40; obj.x //10 obj.y //20 obj.z //40
Object.getProtortypeOf()
function Rectangle(){} var rec = new Rectangle(); Object.getPrototypeOf(rec) === Rectangele.prototype // true
9. 对象的扩展运算符
ES7中提案,将rest参数/扩展运算符(…)引入对象。
Rest参数
Rest参数用于从一个对象取值,相当于将所有可遍历尚未被读取的属性,分配到制定的对象上。所有的键及其值都会复制到新对象上。需要注意的是rest参数的复制是浅复制,并且也不会复制继承自原型对象的属性。
简单的demo
let {x,y,...k} = {x:2, y:3,z:4,a:5}; x //2 y //3 k //{z:4,a:5}
扩展运算符
扩展运算符用于取出参数对象的所有可遍历属性,复制到当前对象中。
let z = {a:3 ,b:4}; let n = {...z}; n //{a:3,b:4}
扩展运算符还可以合并两个对象。
let a = { c:5,d:6 }; let b = { e:7,f:8 }; let ab = {...a,...b}; ab //{c:5,d:6,e:7,f:7}
扩展运算符还可以自定义属性,会在新对象中覆盖掉原有参数。
let a = {x:1,y:2}; let aWithOverides = {...a,x:3,y:4}; aWithOverides //{x:4,y:4}
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对小牛知识库的支持。
本文向大家介绍ES6学习教程之对象字面量详解,包括了ES6学习教程之对象字面量详解的使用技巧和注意事项,需要的朋友参考一下 前言 本文主要给大家介绍了关于ES6对象字面量的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 ECMAScript6使得声明对象字面量更加简单,提供了属性简写和方法简写功能,属性名计算的新特性。 如果可以理解上述三个新特性,可以不必往下阅读。下面
本文向大家介绍ES6学习教程之模板字符串详解,包括了ES6学习教程之模板字符串详解的使用技巧和注意事项,需要的朋友参考一下 模板字符串(template strings) ES6 中引进的一种新型的字符串字面量语法 - 模板字符串。书面上来解释,模板字符串是一种能在字符串文本中内嵌表示式的字符串字面量。简单来讲,就是增加了变量功能的字符串。 ES6为我们提供了模板字符串,语法使用反引号`。模板字符
本文向大家介绍ES6数组的扩展详解,包括了ES6数组的扩展详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了ES6数组的扩展。分享给大家供大家参考,具体如下: 1. Array.from() Array.from()将类数组(array-like)对象与可遍历的对象转化为数组并返回。 下面是一个类数组 ES5我们可能都会这样写: ES6可以把一个类数组转化为一个真正的数组 实际应用中,常
本文向大家介绍详解JS中Array对象扩展与String对象扩展,包括了详解JS中Array对象扩展与String对象扩展的使用技巧和注意事项,需要的朋友参考一下 废话不多说了,直接给大家上array对象扩展代码了,具体代码如下所示: 下面是string对象扩展代码如下所示:
本文向大家介绍JavaScript中的Object对象学习教程,包括了JavaScript中的Object对象学习教程的使用技巧和注意事项,需要的朋友参考一下 参数: (1)obj 必需。Object 对象分配到的变量名称。 (2)值 可选。任一 JavaScript 基元数据类型(数字、布尔值或字符串)。 如果值是一个对象,则返回的对象是未修改的。 如果值是 null、“未定义”或“未提供
本文向大家介绍Angular2学习教程之TemplateRef和ViewContainerRef详解,包括了Angular2学习教程之TemplateRef和ViewContainerRef详解的使用技巧和注意事项,需要的朋友参考一下 TemplateRef 在介绍 TemplateRef 前,我们先来了解一下 HTML 模板元素 - <template> 。模板元素是一种机制,允许包含加载页面时
本文向大家介绍Perl学习教程之单行命令详解,包括了Perl学习教程之单行命令详解的使用技巧和注意事项,需要的朋友参考一下 前言 本文主要给大家介绍了关于Perl单行命令的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 与One-Liner相关的perl参数 -a 自动分隔模式,用空格分隔$并保存在@F中,也就是@F=split //, $ -F 指定-a的分隔符 -l
本文向大家介绍Python 学习教程之networkx,包括了Python 学习教程之networkx的使用技巧和注意事项,需要的朋友参考一下 networkx是Python的一个包,用于构建和操作复杂的图结构,提供分析图的算法。图是由顶点、边和可选的属性构成的数据结构,顶点表示数据,边是由两个顶点唯一确定的,表示两个顶点之间的关系。顶点和边也可以拥有更多的属性,以存储更多的信息。 对于netwo