前端开发那些事儿前端100问

【前端100问】Q74:使用 JavaScript Proxy

2021-02-08  本文已影响0人  alanwhy

写在前面

此系列来源于开源项目:前端 100 问:能搞懂 80%的请把简历给我
为了备战 2021 春招
每天一题,督促自己
从多方面多角度总结答案,丰富知识
使用 JavaScript Proxy 实现简单的数据绑定
简书整合地址:前端 100 问

正文回答

<body>
  hello,world
  <input type="text" id="model">
  <p id="word"></p>
</body>
<script>
  const model = document.getElementById("model")
  const word = document.getElementById("word")
  var obj= {};

  // Proxy 对象用于创建一个对象的代理,从而实现基本操作的拦截和自定义(如属性查找、赋值、枚举、函数调用等)。
  // https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Proxy
  // const p = new Proxy(target, handler)
  const newObj = new Proxy(obj, {
      // 属性读取操作的捕捉器。
      get: function(target, key, receiver) {
        console.log(`getting ${key}!`);
        // Reflect 是一个内置的对象,它提供拦截 JavaScript 操作的方法。这些方法与proxy handlers的方法相同。Reflect不是一个函数对象,因此它是不可构造的。
        // https://developer.mozilla.org/zh-cn/docs/web/javascript/reference/global_objects/reflect
        return Reflect.get(target, key, receiver);
      },
      // 属性设置操作的捕捉器。
      set: function(target, key, value, receiver) {
        console.log('setting',target, key, value, receiver);
        if (key === "text") {
          model.value = value;
          word.innerHTML = value;
        }
        return Reflect.set(target, key, value, receiver);
      }
    });

  model.addEventListener("keyup",function(e){
    newObj.text = e.target.value
  })
</script>
上一篇 下一篇

猜你喜欢

热点阅读