zoukankan      html  css  js  c++  java
  • vue双向绑定的简单实现(原创)

    简单模拟一下vue的双向绑定实现,代码比较粗糙,菜鸟一枚,欢迎各位大佬斧正

    1、实验环境:

    利用a、b两个input,a代表页面中的数据,b代表data中的数据

    2、原理:

    利用Object.defineProperty()方法实现数据的更新;使用oninput(IE下的)和onporpertychange(非IE下的)方法对input框中值的改变进行监听

    3、代码

    注:以下原生js实现

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
    </head>
    <body>
      a: <input type="text" id="a" oninput="aa(event)" onporpertychange="aa(event)">
         </br>
      b: <input type="text" id="b" oninput="bb(event)" onporpertychange="bb(event)">
    </body>
    </html>
    <script>
      var a = document.getElementById('a')
      var b = document.getElementById('b')
      var data = {}
      Object.defineProperty(data, "cell", {
        set: function(newValue) {
          if (newValue) {
            a.value = newValue
            b.value = newValue
          }
        }
      })
    </script>
    <script>
      var ie = !!window.ActiveXObject;
      console.log('111')
      if("onporpertychange" in a){
        document.getElementById("a").attachEvent("onporpertychange",function(e){
          console.log("input");
        })
        document.getElementById("b").attachEvent("onporpertychange",function(e){
          console.log("input");
        })
      } else {
        document.getElementById("a").addEventListener("oninput",function(e){
          console.log("input");
        })
        document.getElementById("b").addEventListener("oninput",function(e){
          console.log("input");
        })
      }
      function aa(e){
        data.cell = a.value
      }
      function bb(e){
        data.cell = b.value
      }
    </script>
  • 相关阅读:
    matlab 绘制条状图形
    细思恐极 天价房都被谁买去了?——如何操作?
    matlab中的containers.Map()
    林彪:怎样当好一个师长?
    matlab 怎么建立结构体数组?
    matlab中patch函数的用法
    Ubuntu 安装配置MySQL,并使用VS的Server Explorer UI界面远程管理MySQL
    CLIQUE 聚类算法以及Java实现+多线程
    R 中同步进行的多组比较的包:npmc
    基于D3JS绘制中国地图
  • 原文地址:https://www.cnblogs.com/hrlin/p/9673920.html
Copyright © 2011-2022 走看看