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)//李四

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

相关推荐
夏梦春蝉4 小时前
ES6从入门到精通:变量
前端·javascript·es6
步行cgn4 小时前
ES6 核心语法手册
前端·javascript·es6
逝缘~1 天前
小白学Pinia状态管理
前端·javascript·vue.js·vscode·es6·pinia
海上彼尚2 天前
Monorepo + PNPM 搭建高效多项目管理
前端·js·源代码管理
巛、3 天前
ES6面试题
前端·面试·es6
程序研4 天前
一、ES6-let声明变量【解刨分析最详细】
前端·javascript·es6
冷凌爱4 天前
Fetch与Axios:区别、联系、优缺点及使用差异
前端·node.js·js
coding随想5 天前
JavaScript ES6 解构:优雅提取数据的艺术
前端·javascript·es6
前端小崔5 天前
前端面试题之ES6保姆级教程
开发语言·前端·javascript·面试·职场和发展·ecmascript·es6
书语时6 天前
ES6 Promise 状态机
前端·javascript·es6