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 相关文章推荐
原生javascript获取元素样式属性值的方法
Dec 25 Javascript
jquery foreach使用示例
Sep 12 Javascript
javascript操作css属性
Dec 30 Javascript
js 去掉空格实例 Trim() LTrim() RTrim()
Jan 07 Javascript
js控制分页打印、打印分页示例
Feb 08 Javascript
javascript随机抽取0-100之间不重复的10个数
Feb 25 Javascript
jquery实现右侧栏菜单选择操作
Mar 04 Javascript
JS制作适用于手机和电脑的通知信息效果
Oct 28 Javascript
基于JS实现9种不同的面包屑和分布式多步骤导航效果
Feb 21 Javascript
关于angularJs清除浏览器缓存的方法
Nov 28 Javascript
在iFrame子页面里实现模态框的方法
Aug 17 Javascript
详解如何在vue项目中使用eslint+prettier格式化代码
Nov 10 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 时间计算问题小结
2009/01/04 PHP
PHP 文件缓存的性能测试
2010/04/25 PHP
PHP版QQ互联OAuth示例代码分享
2015/07/05 PHP
实例讲解php实现多线程
2019/01/27 PHP
Javascript select下拉框操作常用方法
2009/11/09 Javascript
Jquery中获取iframe的代码
2011/01/11 Javascript
js Math 对象的方法
2013/09/01 Javascript
鼠标悬浮停留三秒后自动显示大图js代码
2014/09/09 Javascript
jQuery中last()方法用法实例
2015/01/06 Javascript
深入学习jQuery Validate表单验证(二)
2016/01/18 Javascript
jquery获取复选框的值的简单实例
2016/05/26 Javascript
JS中sort函数排序用法实例分析
2016/06/16 Javascript
AngularJS ng-mousedown 指令
2016/08/02 Javascript
nodejs简单实现操作arduino
2016/09/25 NodeJs
Angular2 路由问题修复详解
2017/03/01 Javascript
jQuery简单实现MD5加密的方法
2017/03/03 Javascript
解决jQuery使用append添加的元素事件无效的问题
2018/08/30 jQuery
Vue加载json文件的方法简单示例
2019/01/28 Javascript
vue实现点击按钮“查看详情”弹窗展示详情列表操作
2020/09/09 Javascript
[38:21]2018DOTA2亚洲邀请赛3月30日 小组赛A组 LGD VS Newbee
2018/03/31 DOTA
[43:26]完美世界DOTA2联赛PWL S2 Forest vs Rebirth 第二场 11.20
2020/11/23 DOTA
Python获取linux主机ip的简单实现方法
2016/04/18 Python
Python之Scrapy爬虫框架安装及简单使用详解
2017/12/22 Python
解读python logging模块的使用方法
2018/04/17 Python
Python实现的括号匹配判断功能示例
2018/08/25 Python
python3 拼接字符串的7种方法
2018/09/12 Python
Django中使用session保持用户登陆连接的例子
2019/08/06 Python
django框架创建应用操作示例
2019/09/26 Python
Python面向对象封装操作案例详解 II
2020/01/02 Python
浅谈基于Canvas的手绘风格图形库Rough.js
2018/03/19 HTML / CSS
教师实习自我鉴定
2013/12/11 职场文书
中餐厅主管的职责范文
2014/02/04 职场文书
网络管理专业求职信
2014/03/15 职场文书
社区活动总结范文
2015/05/07 职场文书
新闻稿怎么写
2015/07/18 职场文书
2016暑期校本培训心得体会
2016/01/08 职场文书