
用法1:替換數組的值
let a = [1,2,3],b = [4,5]
console.log( Object.assign(a,b)); // 后面的值覆蓋前面的值,[4,5,3]
用法2:為對象添加屬性
下面是es5的寫(xiě)法:this.xxx =xxx
// es5的寫(xiě)法
class Test{
constructor(x,y){
this.x =x
this.y = y
}
sum(){
return this.x + this.y
}
}
let t = new Test(1,2)
console.log(t.sum());
用Object.assign的寫(xiě)法
// Object.assign的寫(xiě)法
class Test2{
constructor(x,y){
Object.assign(this,{x,y})
}
sum2(){
return this.x + this.y
}
}
let t2 = new Test2(1,2)
console.log(t2.sum2());
用法3 深度克隆對象
// 用法3 深度克隆對象
let clone = (orignObj) => {
let originProto = Object.getPrototypeOf(orignObj)
return Object.assign(Object.create(originProto), orignObj)
}
let obj3 = { name: 'zs', age: 12 }
console.log(clone(obj3));
用法4:合并對象屬性
下面這種寫(xiě)法,合并后,原來(lái)的兩個(gè)對象都已經(jīng)改變
// example1
let obj = {name:'zs'} ,obj2 = {name:'zs',age:12}
let merge = (target, ...v) => Object.assign(target, ...v)
console.log(merge(obj,obj2));// {name:'zs',age:12}
console.log(obj,obj2); // 合并后,兩個(gè)對象都已經(jīng)改變,值都是 {name:'zs',age:12}
如果不想改變原來(lái)的對象,可以用下面這個(gè)寫(xiě)法
// example2 合并后,返回一個(gè)新對象,不更改原有對象的屬性
let merge2 = (...v) => Object.assign({}, ...v)
console.log(merge2(obj, obj2));// {name:'zs',age:12}
console.log(obj); // 原來(lái)的對象保持原樣 {name:'zs'}
console.log(obj2); // 原來(lái)的對象保持原樣 {name:'zs',age:12}
//合并對象,還可以用展開(kāi)操作符
let obj5 = {name:'zs'},obj6 = {age:12}
let newOjb = {...obj5,...obj6}
console.log(newOjb);
用法5.為默認對象新增屬性
const DEFAULTS = { name: 'zs', age: 13 } // 默認對象
let createObjWithDefault = (opt) => Object.assign({}, DEFAULTS, opt)
console.log(createObjWithDefault({ 'addr': 'gz' }));
呢 稱(chēng): | |
表 情: | |
內 容: |
評論內容:不能超過(guò) 1000 字,需審核,請自覺(jué)遵守互聯(lián)網(wǎng)相關(guān)政策法規。 |
驗證碼: | |
您發(fā)布的評論即表示同意遵守以下條款:
一、不得利用本站危害國家安全、泄露國家秘密,不得侵犯國家、社會(huì )、集體和公民的合法權益;
二、不得發(fā)布國家法律、法規明令禁止的內容;互相尊重,對自己在本站的言論和行為負責;
三、本站對您所發(fā)布內容擁有處置權。