Reflect.get和target[key]有何不同?

主要区别在this指向不同,下面输出张三还是李四?:

javascript 复制代码
  const person={
      name:'张三',
      get FullName(){
          return this.name;
      },
  };
      
  let personProxy=new Proxy(person,{
      get(target,key){
          return Reflect.get(target,key)//或者return target[key]
      }
  });
  const p1={__proto__:personProxy,name:'李四'}
  console.log(p1.FullName)

答案:张三。

当我们读取p1.FullName时,它自身是没有该属性的,也没有指定该属性的getter,它会找到继承自personProxy中,此时会触发get读取target里面的key,此时的target目标对象为person,key为FullName,如果想指定调用者为p1,可以使用第三个参数receiver

javascript 复制代码
const person={
    name:'张三',
    get FullName(){
        return this.name;
    },
};
    
let personProxy=new Proxy(person,{
    get(target,key,receiver){
        return Reflect.get(target,key,receiver)
    }
});
const p1={__proto__:personProxy,name:'李四'}
console.log(p1.FullName)//李四

更多好玩好玩前端知识,可以搜索【坤坤前端笔记】小程序,让我们换个姿势学前端。

相关推荐
Orange3015111 天前
《深入源码理解webpack构建流程》
前端·javascript·webpack·typescript·node.js·es6
gzzeason1 天前
ES6+内置进制转换方法
前端·ecmascript·es6
我命由我123455 天前
软件开发 - 避免过多的 if-else 语句(使用策略模式、使用映射表、使用枚举、使用函数式编程)
java·开发语言·javascript·设计模式·java-ee·策略模式·js
第七种黄昏6 天前
大事件项目拆解:登录访问拦截实现详解
前端框架·vue·js
哈哈哈hhhhhh10 天前
JavaScript进阶ES6
javascript·es6
Zz_waiting.10 天前
Javaweb - 14.1 - 前端工程化
前端·es6
htt232114 天前
前端记录项目中用到的js
前端·ecmascript·es6
PineappleCode14 天前
用 “私房钱” 类比闭包:为啥它能访问外部变量?
前端·面试·js
Warren9815 天前
Java异常讲解
java·开发语言·前端·javascript·vue.js·ecmascript·es6
西岭千秋雪_16 天前
前端工程化:ES6特性
前端·javascript·ecmascript·es6