zoukankan      html  css  js  c++  java
  • vuejs数据双向绑定原理(get & set)

    前端的数据双向绑定指的是view(视图)和model(数据)两者之间的关系;view层是页面上展示给用户看的信息,model层一般是指通过http请求从后台返回的数据。view到model的绑定都是通过事件回调函数操作的,model到view的绑定有多种方法。

    angular,react,vue等mv*模式的框架都实现了数据双向绑定;angular是通过脏检查即新老数据的比较来确定哪些数据发生了变化,从而将它更新到view中;vue则是通过设置数据的get和set函数来实现的,这种方式在性能上是优于angular的。

    下面代码是一个简单的定义数据get和set方法的例子,set和get方法分别在数据改变和访问的时候被调用,能够监听数据的变化:

     1 // 数据绑定的构造函数
     2 function Observer(data) {
     3     this.data = data;
     4 
     5     for(var key in data) {
     6         if(data.hasOwnProperty(key)) {
     7             var val = data[key];
     8             if(typeof data[key] === "object"){
     9                 // 如果值不为原始类型,则继续递归
    10                 new Observer(val);
    11             }else {
    12                 this.convert(key, val);
    13             }
    14         }
    15     }
    16 }
    17 // 定义set 和 get函数
    18 Observer.prototype.convert = function(key, val) {
    19     Object.defineProperty(this.data, key, {
    20         enumerable: true,
    21         confingurable: true,
    22         get: function() {
    23             console.log(key + "被访问了");
    24             return val;
    25         },
    26         set: function(newVal) {
    27             console.log(key + "被设置了新值" + newVal);
    28             val = newVal;
    29         }
    30     });
    31 }
    32 var app = new Observer({name: "xieshuai", age: 24, address: {city: "shenzheng"}});
    33 
    34 app.data.name;       // name被访问了
    35 app.data.age = 18;   // age被设置了新值18

    Object.defineProperty,这是ES5新增的方法,通过这个方法,可以自定义getter和setter函数。

    上面的代码只是个简单的例子,并没有处理数组的情况;不过这是vue实现数据双向绑定的核心。

    本文到此结束,文中若有不对之处,还望指正。

  • 相关阅读:
    Struts2.5 利用Ajax将json数据传值到JSP
    io/nio
    Elasticsearch 、 Logstash以及Kibana 分布式日志
    zookeeper
    mybatis
    Kubemetes
    线程池
    @Builder
    jdk命令行工具系列
    什么是分布式事务
  • 原文地址:https://www.cnblogs.com/xshuai/p/6516680.html
Copyright © 2011-2022 走看看