用Proxy拦截class,这种骚操作闻所未闻!

广告位招租
扫码页面底部二维码联系

一个突发奇想,如果要拦截class的属性【原创不易,请尊重版权】【关注微信公众号:wwwtangshuangnet】变化,除了用defineProperty未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】进行重写,难道不能用Proxy吗?于是,本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net产生了下面这段代码。

【本文受版权保护】【原创不易,请尊重版权】
class A {
  name = 'aaa'
  age = 0
  constructor() {
    return new Proxy(this, {
      get: (_, key) => this[key],
      set: (_, key, value) => {
        console.log(key, value)
        this[key] = value
        return true
      },
    })
  }
  say() {
    console.log(this.name, this.age)
  }
  update(key, value) {
    this[key] = value
  }
}

在构造函数中return new Pro【本文受版权保护】著作权归作者所有,禁止商业用途转载。xy(this)真是够风骚的操作。

本文作者:唐霜,转载请注明出处。【转载请注明来源】
已有1条评论
  1. rxliuli 2020-12-01 12:04

    一般吾辈会用 class static function 或者注解来解决