栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

这两种展开运算符的方式有什么区别呢?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

这两种展开运算符的方式有什么区别呢?

本题在于考察展开运算符...属于浅拷贝
function Super(val) {
this.value = val || 'init'
}
Super.prototype.getTxt = function () {
console.log(

可以访问Super上的方法
);
}

// getTxt方法存在于原型链上: o3.proto.getTxt
const o3 = new Super('OMG')
const obj = { 'key1': 'value1', 'key2': 'value2' }

// 第一种赋值方法没有问题,将o3与obj合并
const o1 = { ...obj, o3 }

// 第二种赋值方法,将o3展开在重新赋值给另一个叫o3的键值
// 展开运算是一种浅拷贝,所以不会拷贝原型链Super上的方法,他的原型是Object
const o2 = { ...obj, o3: { ...o3 } }

console.log(o1.o3.value, typeof o1.o3.getTxt) // OMG, function
console.log(o2.o3.value, typeof o2.o3.getTxt) // OMG, undefined

来源:http://jsrun.pro/C8WKp/edit

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/391371.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号