ES6--》对象扩展方法

简介: ES6语法规范

对象扩展

本文简单介绍以下ES6对对象新增的方法:

name 属性

函数的name属性,返回函数名。对象方法也是函数也有name属性。

<script>constobj= {
name:'张三',
age:18,
sayName(){
console.log('hello world');
        }
    }
console.log(obj.sayName.name);//sayName</script>

如果对象方法使用取值函数(getter)和存值函数(setter),需要该方法的属性的描述对象在对象get和set属性上面,返回值是方法名前加上get和set。

<script>constobj= {
getfoo(){},
setfoo(x){}
    }
constdescriptor=Object.getOwnPropertyDescriptor(obj, 'foo');
console.log(descriptor.get.name);//get foo</script>

有两种特殊情况:

<script>// Function构造函数创造的函数,name属性返回anonymous。console.log((newFunction()).name);//anonymous// bind方法创造的函数,name属性返回bound加上原函数的名字。vardoSomething=function(){}
console.log(doSomething.bind().name);//bound doSomething</script>

属性的遍历

ES6中一共有 5 种方法可以遍历对象的属性。

(1) for...in

循环遍历对象自身属性和继承的可枚举属性

(2)Object.keys(obj)

返回一个数组,包括对象自身的(不含继承的)所有可枚举属性(不含Symbol属性)的键名

(3)Object.getOwnPropertyNames(obj)

返回一个数组,包含对象自身的所有属性(不含Symbol属性,但是包括不可枚举属性)的键名

(4)Object.getOwnPropertySymbols(obj)

返回一个数组,包含对象自身的所有Symbol属性的键名

(5)Reflect.ownKeys(obj)

返回一个数组,包含对象自身的(不含继承的)所有键名,不管键名是Symbol或字符串,也不管是否可枚举。

super关键字

和this关键字总是指向函数所在的当前对象一样,ES6新增了另一个类似的关键字super,指向当前对象的原型对象。

下面代码中,super.say() 指向原型对象 obj 的say方法,但是绑定的this却还是当前对象obj,因此输出的结果不是hello而是world。

<script>constperson= {
x:'hello',
say(){
console.log(this.x);
        }
    }
constobj= {
x:'world',
say(){
super.say()
        }
    }
Object.setPrototypeOf(obj,person)//,该对象将指定对象的原型(即内部[[Prototype]]属性)设置为另一个对象或为null。console.log(obj.say());//world</script>

Object.is()

用来比较两个值是否严格相等,与严格比较运算符(===)的行为基本一致。

<script>varobj= {
name:'张三',
name1:'张三',
gender:'男',
age:18,
say(){
console.log('hello world');
        }
    }
console.log(Object.is(obj.name,obj.name1));//trueconsole.log(Object.is(1,1));//true// Object.is() 和 === 的区别在于以下特殊例子console.log(+0===-0);//trueconsole.log(Object.is(+0,-0));//falseconsole.log(NaN===NaN);//falseconsole.log(Object.is(NaN,NaN));//true</script>

Object.assign()

用于对象的合并,将源对象所有可枚举的属性,复制到目标对象上。

<script>varobj= {
a:1,
b:2,
c:'我是c'    }
varobj1= {
a:2, //当目标对象与源对象有同名属性,或多个源对象有同名属性,则后面的属性会覆盖前面的属性d:3,
e:'我是e'    }
// console.log(Object.assign(target, source1, source2));console.log(Object.assign(obj,obj1));
</script>

用到对象合并我们可以就会遇到一些问题了,请看如下例子:

<script>// 参数不是对象,则会先转换成对象console.log(typeofObject.assign(2)); //object// null和undefined无法转对象,作为目标对象为false,但是作为源对象为true的// console.log(Object.assign(null,2));//报错提醒 Cannot convert undefined or null to object// console.log(Object.assign(2,null));//没报错// 其他类型像数值、字符串、布尔值虽然不会报错,但只有字符串会以数组形式拷入目标对象,其他值不会产生效果constx='abc'consty=123constz=trueconsole.log(Object.assign({},x));//{0: 'a', 1: 'b', 2: 'c'}console.log(Object.assign({},y));//{}console.log(Object.assign({},z));//{}</script>

在使用这个ES6新增的方法时,应该注意以下内容:

<script>// Object.assign()实行的是浅拷贝,如果源对象发生任何变化,都会反映到目标对象上constobj1= {a:1,b:2,c:{d:3}}
constobj2=Object.assign({},obj1)
obj1.c.d=3.14console.log(obj2.c.d);
// Object.assign()可以用来处理数组console.log(Object.assign([1,2,3],[4,5]));// [4, 5, 3]// Object.assign()可以用来对取值函数进行处理,求值之后再处理consta= {
getfoo(){
return1        }
    }
console.log(Object.assign({},a));//{foo: 1}</script>

Object.getOwnPropertyDescriptors()

返回指定对象所有自身属性(非继承属性)的描述对象。

<script>constobj= {
num:12,
getsay(){
return'hello world'        }
    }
console.log(Object.getOwnPropertyDescriptors(obj));
</script>

图片.png

Object.setPrototypeOf()

方法作用与__proto__相同,用来设置应该对象的原型对象(prototype),返回参数对象本身。

<script>letproto= {}
letobj= {x:10}
Object.setPrototypeOf(obj,proto)
proto.y=11proto.z=12console.log(obj.x);//10console.log(obj.y);//11console.log(obj.z);//12</script>

Object.getPrototypeOf()

方法用于读取一个对象的原型对象,与Object.setPrototypeOf()方法配套。

<script>functionfoo(){}
constf=newfoo()
console.log(Object.getPrototypeOf(f) ===foo.prototype);//trueObject.setPrototypeOf(f,Object.prototype)//修改原型对象console.log(Object.getPrototypeOf(f) ===foo.prototype);//false</script>

Object.keys()、Object.values、Object.entries()、Object.fromEntries()

三种方法都是返回一个数组,之间的区别请看如下:

<script>// Object.keys() 返回所有可遍历的键名varobj= {aa:1,bb:'我是b',cc:2}
console.log(Object.keys(obj));//['aa', 'bb', 'cc']// Object.values() 返回所有可遍历的属性的键值,键值排序按属性名数值大小排序iconstobj1= {12:'a',1:'b',18:'c'}
console.log(Object.values(obj1));//['b', 'a', 'c']// Object.entries() 返回所有可遍历属性的键值对数组constobj2= {1:'a','b':2,3:'c'}
console.log(Object.entries(obj2));//[['1', 'a'],['3', 'c'],['b', 2]]// Object.fromEntries() 与 Object.entries()操作相反,将一键值对数组转为对象。console.log(Object.fromEntries([
        ['1', 'a'],
        ['3', 'c'],
        ['b', 2]
    ]));//{1: 'a', 3: 'c', b: 2}</script>

Object.hasOwn()

方法可以判断某个属性是否为原生属性,接受两个参数,第一个是参数是要判断的对象,第二个是属性名。

<script>constobj=Object.create({a:12});
obj.b=34// 对象obj的属性a是继承属性,属性b是原生属性。console.log(Object.hasOwn(obj,'a'));//falseconsole.log(Object.hasOwn(obj,'b'));//true</script>


相关文章
|
数据采集 城市大脑 分布式计算
阿里云产业智能OpenTrek技术升级:发布数字孪生仿真技术架构
2022年11月4日,云栖大会——产业智能技术创新与实践峰会于杭州云栖小镇如期举办,本峰会联合中国科学院院士、中国工程院院士、海外院士与行业权威机构,共同探讨产业智能方法论及发展趋势。会上,阿里云产业智能OpenTrek发布了技术升级后的数字孪生仿真技术架构,为行业数字化转型方向的合作伙伴提供全过程状态数据元信息整合能力,帮助行业客户进行业务价值创新。
阿里云产业智能OpenTrek技术升级:发布数字孪生仿真技术架构
开源测试平台横向测评系列『流马』篇:流马使用及总结
【使用篇】 ● 接口测试:创建接口(添加引用公共参数、添加引用自定义参数)、测试用例(参数关联)、业务流程测试实践 ● web自动化测试:元素管理(添加元素)、测试用例(添加元素)、设计测试场景 ● 测试计划、测试集合与测试用例相互之间的关系 【总结篇】 ● 使用总结:常见的使用注意事项,如变量引用、函数引用、关联参数引用等 ● 优化建议:结合真实使用过程,从用户角度出发,提出的7条优化建议 ● 优缺点总结:优点、缺点、评分(从不同角度评测打分)
开源测试平台横向测评系列『流马』篇:流马使用及总结
|
Python
Python3,5句话实现自动接收短信提醒
Python3,5句话实现自动接收短信提醒
660 0
Python3,5句话实现自动接收短信提醒
|
资源调度
There appears to be trouble with your network connection.Retrying
There appears to be trouble with your network connection.Retrying
2221 0
There appears to be trouble with your network connection.Retrying
|
10月前
|
存储 索引
照片视频彻底删除后,想恢复,如何做呢?从磁盘恢复!
总结来说,照片和视频彻底删除后,只要它们占用的磁盘空间没有被新数据覆盖,就有可能通过数据恢复软件或专业服务来恢复这些文件。恢复的关键在于及时行动,避免数据被覆盖。 从磁盘恢复,原理是什么? 文件系统索引:文件系统通过索引来管理文件,包括文件名、大小和存储位置。当删除文件时,实际上是从索引中移除了文件的引用,但文件数据本身仍然留在存储设备上。
296 4
照片视频彻底删除后,想恢复,如何做呢?从磁盘恢复!
|
12月前
|
SQL DataWorks 搜索推荐
DataWorks 产品评测:数据处理的最佳实践与体验
DataWorks是阿里巴巴云推出的一款综合型大数据开发治理平台,通过此次用户画像分析实践,展现了其在数据整合、分析及可视化方面的强大能力。该平台支持自动化ETL流程,优化了数据资产管理与决策支持,提升了跨部门协作效率,促进了业务创新。相比其他工具,DataWorks具备全面的服务生态、高性能计算能力和高智能化水平,尤其适用于处理大规模数据集。新版Data Studio进一步增强了用户体验,集成了Notebook环境与智能助手Copilot,大幅提高了开发效率。尽管存在一些小问题,但整体上,DataWorks是企业实现数字化转型的理想选择。
255 8
|
自然语言处理 前端开发 数据可视化
Quarto ppt模板制作与Rstudio git连接
本文介绍了当前PPT演示中流行的Quarto文档使用情况,以及如何在Rstudio中连接Git进行版本控制。重点讲解了Quarto的ppt模板制作流程,包括安装、创建演示文稿及自定义样式等步骤,并提供了相关资源链接。
366 0
Quarto ppt模板制作与Rstudio git连接
|
JavaScript API
如何使用Vue 3和Type Script进行组件化设计
【8月更文挑战第16天】如何使用Vue 3和Type Script进行组件化设计
213 3
域名备案
阿里云账号实名认证与域名实名认证可以不一致,备案针对域名实名认证。一个阿里云账号只能有一个备案主体,且主体只能在一个账号上。域名、服务器和备案主体所在账号可以不同,但可通过服务器账号生成备案服务码授权给备案主体账号进行备案。
662 3
|
SQL Oracle 关系型数据库
探索 Linux 命令 `db_archive`:Oracle 数据库归档日志的工具
探索 Linux 中的 `db_archive`,实际与 Oracle 数据库归档日志管理相关。在 Oracle 中,归档日志用于恢复,当在线重做日志满时自动归档。管理员可使用 SQL*Plus 查看归档模式,通过 `RMAN` 进行备份和恢复操作。管理归档日志需谨慎,避免数据丢失。了解归档管理对 Oracle 管理员至关重要,确保故障时能快速恢复数据库。