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

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

相关推荐
Aerelin13 小时前
爬虫playwright中的资源监听
前端·爬虫·js·playwright
怪我冷i1 天前
es6与es5的模块区别
前端·ecmascript·es6·ai写作
西洼工作室1 天前
前端自制设备模拟器模拟不同终端展示效果
前端·css3·js·响应式开发
San30.3 天前
ES6+ 新特性解析:让 JavaScript 开发更优雅高效
开发语言·javascript·es6
八月ouc3 天前
解密JavaScript模块化演进:从IIFE到ES Module,深入理解现代前端工程化基石
javascript·es6·模块化·cmd·commonjs·amd·iife
我命由我123454 天前
微信开发者工具 - 模拟器分离窗口与关闭分离窗口
前端·javascript·学习·微信小程序·前端框架·html·js
fruge4 天前
低版本浏览器兼容方案:IE11 适配 ES6 语法与 CSS 新特性
前端·css·es6
lxh01135 天前
螺旋数组题解
前端·算法·js
前端炒粉5 天前
35.LRU 缓存
开发语言·javascript·数据结构·算法·缓存·js
Nan_Shu_6145 天前
学习:Sass
javascript·学习·es6