位置: IT常识 - 正文

ES6--》对象扩展方法(es6对象扩展运算符)

编辑:rootadmin
ES6--》对象扩展方法

目录

对象扩展

name 属性

属性的遍历

super关键字

Object.is()

Object.assign()

Object.getOwnPropertyDescriptors()

Object.setPrototypeOf()

Object.getPrototypeOf()

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

Object.hasOwn()


对象扩展

推荐整理分享ES6--》对象扩展方法(es6对象扩展运算符),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:es6对象操作,es6对象操作,es6对象操作,es6对象扩展运算符,es6 对象,es6对象的扩展,es6对象新增方法,es6对象扩展运算符,内容如对您有帮助,希望把文章链接给更多的朋友!

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

name 属性

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

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

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

<script> const obj = { get foo(){}, set foo(x){} } const descriptor = Object.getOwnPropertyDescriptor(obj, 'foo'); console.log(descriptor.get.name);//get foo</script>

有两种特殊情况:

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

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

(1) for...in

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

(2)Object.keys(obj)

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

(3)Object.getOwnPropertyNames(obj)

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

ES6--》对象扩展方法(es6对象扩展运算符)

(4)Object.getOwnPropertySymbols(obj)

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

(5)Reflect.ownKeys(obj)

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

super关键字

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

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

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

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

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

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

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

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

<script> // 参数不是对象,则会先转换成对象 console.log(typeof Object.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));//没报错 // 其他类型像数值、字符串、布尔值虽然不会报错,但只有字符串会以数组形式拷入目标对象,其他值不会产生效果 const x = 'abc' const y = 123 const z = true console.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()实行的是浅拷贝,如果源对象发生任何变化,都会反映到目标对象上 const obj1 = {a:1,b:2,c:{d:3}} const obj2 = Object.assign({},obj1) obj1.c.d = 3.14 console.log(obj2.c.d); // Object.assign()可以用来处理数组 console.log(Object.assign([1,2,3],[4,5]));// [4, 5, 3] // Object.assign()可以用来对取值函数进行处理,求值之后再处理 const a = { get foo(){ return 1 } } console.log(Object.assign({},a));//{foo: 1}</script>Object.getOwnPropertyDescriptors()

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

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

Object.setPrototypeOf()

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

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

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

<script> function foo(){} const f = new foo() console.log(Object.getPrototypeOf(f) === foo.prototype);//true Object.setPrototypeOf(f,Object.prototype)//修改原型对象 console.log(Object.getPrototypeOf(f) === foo.prototype);//false</script>Object.keys()、Object.values、Object.entries()、Object.fromEntries()

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

<script> // Object.keys() 返回所有可遍历的键名 var obj = {aa:1,bb:'我是b',cc:2} console.log(Object.keys(obj));//['aa', 'bb', 'cc'] // Object.values() 返回所有可遍历的属性的键值,键值排序按属性名数值大小排序i const obj1 = {12:'a',1:'b',18:'c'} console.log(Object.values(obj1));//['b', 'a', 'c'] // Object.entries() 返回所有可遍历属性的键值对数组 const obj2 = {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> const obj = Object.create({a:12}); obj.b = 34 // 对象obj的属性a是继承属性,属性b是原生属性。 console.log(Object.hasOwn(obj,'a'));//false console.log(Object.hasOwn(obj,'b'));//true</script>
本文链接地址:https://www.jiuchutong.com/zhishi/300307.html 转载请保留说明!

上一篇:unplugin-auto-import的使用(unplugin-auto-import github)

下一篇:【视觉SLAM】SO-SLAM: Semantic Object SLAM With Scale Proportional and Symmetrical Texture Constraints(视觉slam十四讲笔记)

  • 微信怎么隐藏微信钱包下方金额(微信怎么隐藏微信名)

    微信怎么隐藏微信钱包下方金额(微信怎么隐藏微信名)

  • 1688能退货吗(1688能退换货吗)

    1688能退货吗(1688能退换货吗)

  • 字符1的ascii码值(字符1的ascii码值16进制)

    字符1的ascii码值(字符1的ascii码值16进制)

  • 钉钉头像为什么显示不出来(钉钉头像为什么不更新)

    钉钉头像为什么显示不出来(钉钉头像为什么不更新)

  • RecycleBinHW文件可以删除(recyclebinhw里的文件)

    RecycleBinHW文件可以删除(recyclebinhw里的文件)

  • oppo与vivo什么关系(oppo,vivo关系)

    oppo与vivo什么关系(oppo,vivo关系)

  • 换了手机号QQ登不上去怎么办(换了手机号qq登不上 无法验证身份)

    换了手机号QQ登不上去怎么办(换了手机号qq登不上 无法验证身份)

  • 抖音视频什么时候发点击率高(抖音视频什么时候投dou+)

    抖音视频什么时候发点击率高(抖音视频什么时候投dou+)

  • 华为手机密码怎么设置在哪里(华为手机密码怎么打开)

    华为手机密码怎么设置在哪里(华为手机密码怎么打开)

  • ipad air3有耳机孔吗(ipadair3有耳机插孔吗)

    ipad air3有耳机孔吗(ipadair3有耳机插孔吗)

  • 微信支付怎么设置刷脸(微信支付怎么设置指纹)

    微信支付怎么设置刷脸(微信支付怎么设置指纹)

  • pr光流法是什么意思(prcc2015光流法)

    pr光流法是什么意思(prcc2015光流法)

  • 移动宽带没网络是什么原因(移动宽带没网络怎么办)

    移动宽带没网络是什么原因(移动宽带没网络怎么办)

  • 监控怎么删除一段视频(监控怎么删除一个月的)

    监控怎么删除一段视频(监控怎么删除一个月的)

  • 三星手机有语音助手吗(三星手机有语音唤醒吗)

    三星手机有语音助手吗(三星手机有语音唤醒吗)

  • 键盘上没有fn键怎么办(键盘上没有fn键怎么换灯光)

    键盘上没有fn键怎么办(键盘上没有fn键怎么换灯光)

  • 电脑网络显示x(电脑网络显示X,但能上网)

    电脑网络显示x(电脑网络显示X,但能上网)

  • 努比亚红魔3S有耳机孔吗(努比亚红魔3s有耳机吗)

    努比亚红魔3S有耳机孔吗(努比亚红魔3s有耳机吗)

  • 小遛共享怎么退钱(小遛共享怎么退余额)

    小遛共享怎么退钱(小遛共享怎么退余额)

  • 30倍变焦手机有哪些(手机30倍变焦相当于多少米)

    30倍变焦手机有哪些(手机30倍变焦相当于多少米)

  • 微信扫了一个辅助的码怎么办(微信扫一扫显示辅助成功是什么意思)

    微信扫了一个辅助的码怎么办(微信扫一扫显示辅助成功是什么意思)

  • vivox27微信有美颜功能吗(vivo手机有美颜吗)

    vivox27微信有美颜功能吗(vivo手机有美颜吗)

  • 华为nova5pro怎样分屏(华为nova5pro怎样连接u 盘)

    华为nova5pro怎样分屏(华为nova5pro怎样连接u 盘)

  • 华为手机智慧视觉是什么(华为手机智慧视觉是什么意思)

    华为手机智慧视觉是什么(华为手机智慧视觉是什么意思)

  • vue添加自定义音乐(vue 添加自定义属性)

    vue添加自定义音乐(vue 添加自定义属性)

  • 手机播放视频怎么连接电视(手机播放视频怎么投屏到电脑上)

    手机播放视频怎么连接电视(手机播放视频怎么投屏到电脑上)

  • 居间费用如何纳税
  • 员工提成比例怎么分配
  • 电子承兑汇票兑现
  • 企业所得税视同销售的会计处理
  • 烟叶税税率计算方法
  • 怎么看运费
  • 银行基本户可以变更成一般户吗
  • 车险会计分录处理怎么写
  • 固定资产大修理的标准
  • 适用于6%税率的优惠
  • 丢失支票补救措施
  • 合并财务报表内部固定资产交易的抵消
  • 现金日记账年结模板
  • 可供分配利润包含哪些
  • 高管培训费不能税前列支
  • 与收益相关政府补助区分总额法净额法吗
  • 非货币性资产交换损益计算
  • 发票抵税是指哪些内容
  • 增值税普通发票和专用发票有什么区别
  • 一般纳税人吧
  • 增值税发票过期了税金怎么办
  • 定额发票有效期是多长时间?你知道吗?
  • 自己公司开发票有什么好处
  • 零售超豪华小汽车交消费税吗
  • 景区中设立的经济组织是
  • 商业健康保险个人所得税扣除
  • 电子承兑汇票怎么打印出来
  • 小规模纳税人增值税超过30万怎么纳税
  • 华为鸿蒙系统的服务
  • 广告制作包括印花吗
  • 股票股利和现金股利的共同点
  • 清算所得税申报表范本
  • win7为什么现在不能用了
  • 以租代购算固定资产吗
  • 增加注册资本的请示
  • ChatGLM-6B (介绍相关概念、基础环境搭建及部署)
  • php表单生成器
  • 后台管理系统权限管理详解
  • 固定资产抵债账务怎么处理
  • 残疾人增值税即征即退税收减免备案
  • 固定资产明细账登记
  • 蒙特维德云雾森林
  • 前端axios请求怎么中断
  • thinkphp6.0完全开发手册
  • 房地产企业出售房产增值税
  • 为什么其他权益工具投资不计提减值准备
  • 使用筷子就餐会不会传染乙肝病毒
  • 企业为其他企业担保有什么责任
  • 公积金提取条件资料
  • 公益组织可以开公司吗
  • 工会经费缴纳方式的文件
  • mysql外键约束的基本语法结构
  • 简述记账后的凭证修改方法
  • 公司不交工会经费有什么后果?工会经费交费时自愿的么?
  • 工程的直接成本包括哪些内容
  • 企业零申报怎么办
  • 补缴纳税款
  • 银行手续费如何做账务处理
  • 合并企业如何缴纳印花税
  • 委托加工合同如何签订
  • 工程行业收到工程发票
  • 开票金额含税金的计算方法
  • 五金行业怎么开店
  • xp不能安装win8
  • win10以管理员身份登录电脑
  • linux引导程序有哪些
  • perl 调用perl
  • python快速上手 自动化
  • 编写shell脚本,批量建立用户
  • node cd
  • 用jquery
  • 苏州峰谷电怎么申请
  • 四川税务局发票下载
  • 企业的绿化用地暂免征收土地使用税
  • 洗煤与选煤
  • 股权转让本人不签字可以吗
  • 开通税务在哪里弄
  • 珠海车船税的缴纳地点
  • 广东省地方税务局发票在线应用系统
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设