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

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

相关推荐
吃西瓜不吐籽_1 天前
2026 届前端校招冲刺:2 万字高频面试题库(含详解、追问与评分标准)
前端·javascript·css·typescript·前端框架·es6
保持当下18 天前
分享一些程序员很棘手但是却又简单的工具
程序员·免费·js·工具
888CC++19 天前
箭头函数(ES6)
前端·javascript·es6
xiaofeichaichai23 天前
ES 新特性九年速览:从 ES2016 到 ES2024
前端·javascript·es6
Xzh042324 天前
Web 前端开发 — 期末复习指南(Html、Css、Js)
css·html5·web·js·期末
蜂蜜黄油呀土豆25 天前
Agent 循环:观察、思考、行动(ReAct 入门)
python·ai·大模型·react·js
川冰ICE1 个月前
JavaScript高级④|类(class)与面向对象,ES6现代写法
开发语言·javascript·es6
步十人1 个月前
【Vue3】前置知识简单概述(包括ES6核心语法,模块化ESM以及npm基础)
arcgis·npm·vue·es6
研☆香1 个月前
es6新特性功能介绍(四)
前端·ecmascript·es6
YHHLAI1 个月前
Prompt 做 NLP 任务开发|ES6 + 模块化
自然语言处理·prompt·es6