Object.defineProperty和Proxy对对象的修改和添加

1.Object.defineProperty(target, property,desc )

const obj = {a: 1,b:2}
Object.defineProperty(obj,'c',{value:3})
console.log(obj)   // {a: 1,b:2,c: 3}

2.Proxy(target, handler) 不仅可以对对象还可以对数组进行修改

const obj = {a: 1,b:2}
const proxyValue = new Proxy(obj,{
  get: (target, propKey, receiver)=>{
   return Reflect.get(target, propKey, receiver)
 },
  set: (target, propKey, value, receiver)=>{
   return Reflect.set(target, propKey, value, receiver)
 }
})
proxyValue.c = 3
console.log(proxyValue)   // {a: 1,b:2,c:3}
const arr = [{a: 1},{b:2}]
const proxyValue = new Proxy(arr,{
  get: (target, propKey, receiver)=>{
   return Reflect.get(target, propKey, receiver)
 },
  set: (target, propKey, value, receiver)=>{
   return Reflect.set(target, propKey, value, receiver)
 }
})
proxyValue.push({d:343})   // [{a: 1},{b:2},{d:343}]

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值