全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Vue.js双向绑定实现原理详解

Vue.js最核心的功能有两个,一是响应式的数据绑定系统,二是组件系统。本文仅探究几乎所有Vue的开篇介绍都会提到的hello world双向绑定是怎样实现的。先讲涉及的知识点,再参考源码,用尽可能少的代码实现那个hello world开篇示例。

参考文章:https://www./article/100819.htm

一、访问器属性

访问器属性是对象中的一种特殊属性,它不能直接在对象中设置,而必须通过defineProperty()方法单独定义。

var obj = { };

// 为obj定义一个名为hello的访问器属性

Object.defineProperty(obj, "hello", {

get: function () {return sth},

set: function (val) {/* do sth */}

})

obj.hello // 可以像普通属性一样读取访问器属性

访问器属性的"值"比较特殊,读取或设置访问器属性的值,实际上是调用其内部特性:get和set函数。

obj.hello // 读取属性,就是调用get函数并返回get函数的返回值

obj.hello = "abc" // 为属性赋值,就是调用set函数,赋值其实是传参

get和set方法内部的this都指向obj,这意味着get和set函数可以操作对象内部的值。另外,访问器属性的会"覆盖"同名的普通属性,因为访问器属性会被优先访问,与其同名的普通属性则会被忽略(也就是所谓的被"劫持"了)。

二、极简双向绑定的实现

此例实现的效果是:随文本框输入文字的变化,span中会同步显示相同的文字内容;在js或控制台显式的修改obj.name的值,视图会相应更新。这样就实现了model =>view以及view => model的双向绑定,并且是响应式的。

以上就是Vue实现双向绑定的基本原理。

三、分解任务

上述示例仅仅是为了说明原理。我们最终要实现的是:

首先将该任务分成几个子任务:

   1、输入框以及文本节点与data中的数据绑定

   2、输入框内容变化时,data中的数据同步变化。即view => model的变化。

   3、data中的数据变化时,文本节点的内容同步变化。即model => view的变化。

要实现任务一,需要对DOM进行编译,这里有一个知识点:DocumentFragment。

四、DocumentFragment

DocumentFragment(文档片段)可以看作节点容器,它可以包含多个子节点,当我们将它插入到DOM中时,只有它的子节点会插入目标节点,所以把它看作一组节点的容器。使用DocumentFragment处理节点,速度和性能远远优于直接操作DOM。Vue进行编译时,就是将挂载目标的所有子节点劫持(真的是劫持)到DocumentFragment中,经过一番处理后,再将DocumentFragment整体返回插入挂载目标。

五、数据初始化绑定

以上代码实现了任务一,我们可以看到,hello world已经呈现在输入框和文本节点中。

六、响应式的数据绑定

再来看任务二的实现思路:当我们在输入框输入数据的时候,首先触发input事件(或者keyup、change事件),在相应的事件处理程序中,我们获取输入框的value并赋值给vm实例的text属性。我们会利用defineProperty将data中的text劫持为vm的访问器属性,因此给vm.text赋值,就会触发set方法。在set方法中主要做两件事,第一是更新属性的值,第二留到任务三再说。

任务二也就完成了,text属性值会与输入框的内容同步变化:

七、订阅/发布模式(subscribe&publish)

text属性变化了,set方法触发了,但是文本节点的内容没有变化。如何让同样绑定到text的文本节点也同步变化呢?这里又有一个知识点:订阅发布模式。

订阅发布模式(又称观察者模式)定义了一种一对多的关系,让多个观察者同时监听某一个主题对象,这个主题对象的状态发生改变时就会通知所有观察者对象。

发布者发出通知 => 主题对象收到通知并推送给订阅者 => 订阅者执行相应操作

之前提到的,当set方法触发后做的第二件事就是作为发布者发出通知:“我是属性text,我变了”。文本节点则是作为订阅者,在收到消息后执行相应的更新操作。

八、双向绑定的实现

回顾一下,每当new一个Vue,主要做了两件事:第一个是监听数据:observe(data),第二个是编译HTML:nodeToFragement(id)。

在监听数据的过程中,会为data中的每一个属性生成一个主题对象dep。

在编译HTML的过程中,会为每个与数据绑定相关的节点生成一个订阅者watcher,watcher会将自己添加到相应属性的dep中。

我们已经实现:修改输入框内容 => 在事件回调函数中修改属性值 => 触发属性的set方法。

接下来我们要实现的是:发出通知dep.notify() => 触发订阅者的update方法 => 更新视图。

这里的关键逻辑是:如何将watcher添加到关联属性的dep中。

在编译HTML过程中,为每个与data关联的节点生成一个Watcher。Watcher函数中发生了什么呢?

首先,将自己赋给了一个全局变量Dep.target;

其次,执行了update方法,进而执行了get方法,get的方法读取了vm的访问器属性,从而触发了访问器属性的get方法,get方法中将该watcher添加到了对应访问器属性的dep中;

再次,获取属性的值,然后更新视图。

最后,将Dep.target设为空。因为它是全局变量,也是watcher与dep关联的唯一桥梁,任何时刻都必须保证Dep.target只有一个值。

至此,hello world双向绑定就基本实现了。文本内容会随输入框内容同步变化,在控制器中修改vm.text的值,会同步反映到文本内容中(但输入框还没有绑定,读者可以自己试试)。

完整代码:https://github.com/bison1994/two-way-data-binding

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Vue.js  # 双向绑定  # 深入理解vue.js双向绑定的实现原理  # 解析Vue2.0双向绑定实现原理  # 如何理解Vue的作用域插槽的实现原理  # Vue底层实现原理总结  # 浅谈vue中数据双向绑定的实现原理  # Vue中的基础过渡动画及实现原理解析  # Vue分页器实现原理详解  # Vue 2.0的数据依赖实现原理代码简析  # 浅析vue中的MVVM实现原理  # 浅析vue-router实现原理及两种模式  # Vue简单实现原理详解  # 绑定  # 输入框  # 的是  # 件事  # 过程中  # 多个  # 实现了  # 当我们  # 会为  # 将该  # 象中  # 我是  # 全局变量  # 就会  # 还没有  # 第一个  # 也就  # 一是  # 则是  # 又有 


相关文章: 建站上市公司网站建设方案与SEO优化服务定制指南  攀枝花网站建设,攀枝花营业执照网上怎么年审?  如何在橙子建站上传落地页?操作指南详解  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  子杰智能建站系统|零代码开发与AI生成SEO优化指南  C++中引用和指针有什么区别?(代码说明)  建站之星如何通过成品分离优化网站效率?  html制作网站的步骤有哪些,iapp如何添加网页?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  北京专业网站制作设计师招聘,北京白云观官方网站?  如何获取开源自助建站系统免费下载链接?  b2c电商网站制作流程,b2c水平综合的电商平台?  ,柠檬视频怎样兑换vip?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  建站之星2.7模板快速切换与批量管理功能操作指南  c# 在高并发场景下,委托和接口调用的性能对比  如何在云虚拟主机上快速搭建个人网站?  ,购物网站怎么盈利呢?  建站之星后台管理如何实现高效配置?  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  如何做网站制作流程,*游戏网站怎么搭建?  高性能网站服务器配置指南:安全稳定与高效建站核心方案  在线制作视频的网站有哪些,电脑如何制作视频短片?  如何在香港免费服务器上快速搭建网站?  全景视频制作网站有哪些,全景图怎么做成网页?  详解jQuery中基本的动画方法  魔方云NAT建站如何实现端口转发?  郑州企业网站制作公司,郑州招聘网站有哪些?  行程制作网站有哪些,第三方机票电子行程单怎么开?  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  湖北网站制作公司有哪些,湖北清能集团官网?  网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?  制作门户网站的参考文献在哪,小说网站怎么建立?  浅谈Javascript中的Label语句  小说建站VPS选用指南:性能对比、配置优化与建站方案解析  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何快速搭建高效服务器建站系统?  北京建设网站制作公司,北京古代建筑博物馆预约官网?  香港服务器建站指南:免备案优势与SEO优化技巧全解析  代刷网站制作软件,别人代刷火车票靠谱吗?  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  哈尔滨网站建设策划,哈尔滨电工证查询网站?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  个人网站制作流程图片大全,个人网站如何注销?  C#如何在一个XML文件中查找并替换文本内容  韩国服务器如何优化跨境访问实现高效连接? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。