zoukankan      html  css  js  c++  java
  • proxy实现数据双向绑定

    Proxy 也就是代理,可以帮助我们完成很多事情,例如对数据的处理,对构造函数的处理,对数据的验证,说白了,就是在我们访问对象前添加了一层拦截,可以过滤很多操作,而这些过滤,由你来定义。
     

    语法

    let p = new Proxy(target, handler);

    参数

    1. target :需要使用Proxy包装的目标对象(可以是任何类型的对象,包括原生数组,函数,甚至另一个代理)。
    2. handler: 一个对象,其属性是当执行一个操作时定义代理的行为的函数(可以理解为某种触发器)。

    需要注意的一个点是,如果是在严格模式下使用proxy,在set方法中需要return true,否则会报错;

    下面是数据双向绑定的简单实现 

    // html
    <input type="text" v-model='content'>
    <div v-bind='content'></div>
    <hr>
    <input type="text" v-model='title'>
    <input type="text" v-model='title'>
    <div v-bind='title'></div>
    // 数据双向绑定
    function View() {
      let proxy = new Proxy({}, {
        get() { },
        set(obj, key, value) {
          document.querySelectorAll(`[v-model=${key}]`).forEach(item => {
            item.value = value;
          });
          document.querySelectorAll(`[v-bind=${key}]`).forEach(item => {
            item.innerHTML = value;
          })
        return true } })
    this.init = () => { document.querySelectorAll('[v-model]').forEach(item => { item.addEventListener('keyup', function () { proxy[this.getAttribute('v-model')] = this.value; }) }) } } new View().init();
  • 相关阅读:
    java反射小练习
    Set与list测试
    关于用户界面
    自定义标签打包使用问题
    jsp中获取当前访问路径
    LeetCode 汇总
    LeetCode 46. 全排列
    LeetCode 40.组合总和II
    LeetCode 39.组合总和
    LeetCode 37.解数独
  • 原文地址:https://www.cnblogs.com/kewenxin/p/14517526.html
Copyright © 2011-2022 走看看