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 相关文章推荐
基于Jquery的实现回车键Enter切换焦点
Sep 14 Javascript
读jQuery之七 判断点击了鼠标哪个键的代码
Jun 21 Javascript
漂亮的jquery提示效果(仿腾讯弹出层)
Feb 05 Javascript
基于javascipt-dom编程 table对象的使用
Apr 22 Javascript
AngularJS入门教程之双向绑定详解
Aug 18 Javascript
js中获取键盘按下键值event.keyCode、event.charCode和event.which的兼容性详解
Mar 15 Javascript
vue.js从安装到搭建过程详解
Mar 17 Javascript
vue下拉菜单组件(含搜索)的实现代码
Nov 25 Javascript
利用Vconsole和Fillder进行移动端抓包调试方法
Mar 05 Javascript
小程序中英文混合排序问题解决
Aug 02 Javascript
js+canvas实现图片格式webp/png/jpeg在线转换
Aug 22 Javascript
vue+Element-ui实现登录注册表单
Nov 17 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在线代理转向代码
2012/05/05 PHP
php调用Google translate_tts api实现代码
2013/08/07 PHP
php+js实现百度地图多点标注的方法
2016/11/30 PHP
Eclipse PHPEclipse 配置的具体步骤
2017/08/08 PHP
laravel实现上传图片的两种方式小结
2019/10/12 PHP
基础的prototype.js常用函数及其用法
2007/03/10 Javascript
拖拉表格的JS函数
2008/11/20 Javascript
js+CSS 图片等比缩小并垂直居中实现代码
2008/12/01 Javascript
获取网站跟路径的javascript代码(站点及虚拟目录)
2009/10/20 Javascript
JSON 教程 json入门学习笔记
2020/09/22 Javascript
jquery提示效果实例分析
2014/11/25 Javascript
jQuery源码解读之addClass()方法分析
2015/02/20 Javascript
jQuery实现延迟跳转的方法
2015/06/05 Javascript
JS+CSS实现精美的二级导航效果代码
2015/09/17 Javascript
第三章之Bootstrap 表格与按钮功能
2016/04/25 Javascript
Vue组件化开发思考
2018/02/02 Javascript
async/await优雅的错误处理方法总结
2019/01/30 Javascript
你或许不知道的一些npm实用技巧
2019/07/04 Javascript
openlayers实现地图弹窗
2020/09/25 Javascript
[05:26]2014DOTA2西雅图国际邀请赛 iG战队巡礼
2014/07/07 DOTA
[01:30:55]VG vs Mineski Supermajor 败者组 BO3 第三场 6.6
2018/06/07 DOTA
详解Python验证码识别
2016/01/25 Python
Python 实现王者荣耀中的敏感词过滤示例
2019/01/21 Python
Python实现合并两个有序链表的方法示例
2019/01/31 Python
浅谈Python3多线程之间的执行顺序问题
2020/05/02 Python
HTML5仿手机微信聊天界面
2016/03/18 HTML / CSS
HTML5 文件域+FileReader 分段读取文件并上传到服务器
2017/10/23 HTML / CSS
英国马莎百货印度官网:Marks & Spencer印度
2020/10/08 全球购物
档案接收函
2014/01/13 职场文书
小学生自我评价100字(15篇)
2014/09/18 职场文书
关于运动会广播稿300字
2014/10/05 职场文书
离婚协议书应该怎么写
2014/10/12 职场文书
赵乐秦在党的群众路线教育实践活动总结大会上的讲话稿
2014/10/25 职场文书
2014年帮扶工作总结
2014/11/26 职场文书
Vue3 Composition API的使用简介
2021/03/29 Vue.js
浅谈vue2的$refs在vue3组合式API中的替代方法
2021/04/18 Vue.js