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

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

相关推荐
全栈凯哥16 小时前
ES6 (ECMAScript 2015) 详解
前端·ecmascript·es6
wxl7812271 天前
坐席业绩数据分析
html·js·csv·bi
海盐泡泡龟2 天前
ES6新增Set、Map两种数据结构、WeakMap、WeakSet举例说明详细。(含DeepSeek讲解)
前端·数据结构·es6
Code_Geo3 天前
在js中大量接口调用并发批量请求处理器
js·接口调用·并发请求
帅云毅3 天前
Screeps Arena基础入门
学习·js·印象笔记
Mr.闻吉安3 天前
什么是变量提升?
javascript·es6
七灵微4 天前
ES6入门---第三单元 模块七: Proxy的使用+Reflect的使用
javascript·vue.js·es6
年纪轻轻只想躺平4 天前
JavaScript ES6+ 最佳实践
前端·javascript·es6
layman05284 天前
ES6/ES11知识点 续五
前端·ecmascript·es6
prog_61035 天前
【笔记】当个自由的书籍收集者从canvas得到png转pdf
pdf·canvas·js·png