vue双向绑定简要分析


Posted in Javascript onMarch 23, 2017

Vue是当前很火的一款MVVM的轻量级框架,它是以数据驱动和组件化的思想构建的。因为它提供了简洁易于理解的api,使得我们很容易上手。

Vue与MVVM 如果你之前已经习惯了用jQuery操作DOM,学习Vue.js时请先抛开手动操作DOM的思维,因为Vue.js是数据驱动的,你无需手动操作DOM。Vue以数据为驱动,将自身的Dom元素与数据进行绑定,一旦创建绑定,Dom和数据保持同步。

vue双向绑定简要分析

其中ViewModel是Vue的核心,它是Vue的一个实例,作用于某个HTML元素上,可以是body也可以是某个id所指代的元素。双向绑定主流双向数据绑定实现原理

脏值检测 : 这是AngularJS实现双向数据绑定的方式。 原理是 当数据进行变更的时候对所有Model和View的绑定关系进行一次检查,识别是否有数据进行了变更,如果有变化则进行处理,由于可能进一步引发其他数据的改变,会再次循环这个过程,知道没有数据的变化之后。发送数据到视图重新渲染。 可想而知,这样的方式性能不高。

数据劫持: Vue采用的是 ES5的 Object,defineProperty() 方法,使用getter/setter监测对数据的操作,从而通知绑定是视图进行更新。 由于是在不同是数据上进行触发,可以精确的更新绑定的视图,而不是对所有的数据进行检测。

vue双向绑定简要分析

Vue是通过数据劫持的方式进行双向数据绑定的,最核心的方法就是 Object.defineProperty来实现对数据的劫持,检测数据的变化。
双向绑定的实现分为三个步骤:
1.实现一个数据监听器,能够对数据对象的所有属性进行监听,如有变动可拿到最新值并通知订阅者。
2.实现一个指令解析器,对每个元素的节点的指令进行解析。根据指令模板替换数据,以及绑定相应的更新函数。
3.实现一个观察者,能够订阅并收到每个属性变化的通知,执行指令绑定的相应回调函数,从而更新视图。

实现双向数据绑定核心代码:

vue双向绑定简要分析
vue双向绑定简要分析 

Dep类是一个订阅者类, 它具有一个订阅者数组与当前属性对应。关联当前数据和所有的 watcher 的依赖关系。
Dep.target是一个暴露出来的全局属性,暂存Watcher, 再添加完之后就会释放。
而在set中如果发现值的变换则通知所有订阅者(watcher)更新视图。

举例

vue双向绑定简要分析 

如果你对于Vue有一定了解的话,那么实现这个效果并不难。

<div id="demo">
 <p>{{message}}</p>
 <input type="text" v-model="message"/>
</div>

var App = new Vue({ 
 el: "#demo",
 data: { 
  message: 'Hello,World!'
 }
})

如果你想说我用jquery也可以实现,的确是这样:

<div id="box">
   <p class="text"></p>
   <input type="text" id="inputText">
   <script type="text/javascript" src="jquery.js"></script>
   <script type="text/javascript">
    $("#inputText").on("input", function() {
      var value = $(this).val() 
      $('.text').text(value)
    })
   </script>

这么来形容吧:jquery开发项目好比是老式的纺织机,而用Vue+Webpack开发好比是现代纺织工厂。区别就是一个上手容易,一个在生产效率,多成员协同,管理等方面却是质的飞跃。

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

Javascript 相关文章推荐
use jscript with List Proxy Server Information
Jun 11 Javascript
CSS+jQuery实现简单的折叠菜单
Dec 20 Javascript
微信小程序 input输入框详解及简单实例
Jan 10 Javascript
浅谈js中用$(#ID)来作为选择器的问题(id重复的时候)
Feb 14 Javascript
jquery拼接ajax 的json和字符串拼接的方法
Mar 11 Javascript
基于 webpack2 实现的多入口项目脚手架详解
Jun 26 Javascript
AngularJs ng-change事件/指令的用法小结
Nov 01 Javascript
Node.js实现发送邮件功能
Nov 06 Javascript
layer.open 子页面弹出层向父页面传输数据的例子
Sep 26 Javascript
深入分析JavaScript 事件循环(Event Loop)
Jun 19 Javascript
vue实现移动端项目多行文本溢出省略
Jul 29 Javascript
基于JavaScript实现省市联动效果
Jun 22 Javascript
Javascript面试经典套路reduce函数查重
Mar 23 #Javascript
JQuery 进入页面默认给已赋值的复选框打钩
Mar 23 #jQuery
vue.js实现含搜索的多种复选框(附源码)
Mar 23 #Javascript
js手机号4位显示空格,银行卡每4位显示空格效果
Mar 23 #Javascript
JS实现两周内自动登录功能
Mar 23 #Javascript
面试常见的js算法题
Mar 23 #Javascript
Vue.Js中的$watch()方法总结
Mar 23 #Javascript
You might like
PHP字符转义相关函数小结(php下的转义字符串)
2007/04/12 PHP
PHP下通过file_get_contents的代理使用方法
2011/02/16 PHP
PHP对文件夹递归执行chmod命令的方法
2015/06/19 PHP
php正则匹配文章中的远程图片地址并下载图片至本地
2015/09/29 PHP
PHP实现图片的等比缩放和Logo水印功能示例
2017/05/04 PHP
PHP实现基于图的深度优先遍历输出1,2,3...n的全排列功能
2017/11/10 PHP
js innerHTML 的一些问题的解决方法
2008/06/22 Javascript
js对象之JS入门之Array对象操作小结
2011/01/09 Javascript
基于jQuery实现的Ajax 验证用户名是否存在的实现代码
2011/04/06 Javascript
JavaScript、jQuery与Ajax的关系
2016/01/24 Javascript
Javascript 一些需要注意的细节(必看篇)
2017/07/08 Javascript
Vue组件通信实践记录(推荐)
2017/08/15 Javascript
vue-cli脚手架引入图片的几种方法总结
2018/03/13 Javascript
vue 优化CDN加速的方法示例
2018/09/19 Javascript
vuex存值与取值的实例
2019/11/06 Javascript
微信小程序button标签open-type属性原理解析
2020/01/21 Javascript
[54:51]Ti4 冒泡赛第二轮LGD vs C9 3
2014/07/14 DOTA
Python实现端口复用实例代码
2014/07/03 Python
在Python中使用SQLite的简单教程
2015/04/29 Python
Python中for循环控制语句用法实例
2015/06/02 Python
基于django ManyToMany 使用的注意事项详解
2019/08/09 Python
Python使用get_text()方法从大段html中提取文本的实例
2019/08/27 Python
Python 导入文件过程图解
2019/10/15 Python
Python使用Opencv实现图像特征检测与匹配的方法
2019/10/30 Python
Python对wav文件的重采样实例
2020/02/25 Python
Python Selenium安装及环境配置的实现
2020/03/17 Python
python百行代码自制电脑端网速悬浮窗的实现
2020/05/12 Python
Python pip安装模块提示错误解决方案
2020/05/22 Python
浅谈keras中Dropout在预测过程中是否仍要起作用
2020/07/09 Python
蜜蜂引路教学反思
2014/02/04 职场文书
施工材料员岗位职责
2014/02/12 职场文书
学前班学生评语
2014/12/29 职场文书
教师工作决心书
2015/02/04 职场文书
2016开学第一课心得体会
2016/01/23 职场文书
Vue监视数据的原理详解
2022/02/24 Vue.js
AJAX引擎原理以及XmlHttpRequest对象的axios、fetch区别详解
2022/04/09 Javascript