Vue实现双向数据绑定


Posted in Javascript onMay 03, 2017

Vue实现双向数据绑定的方式,具体内容如下

Vue是如何实现双向数据绑定的呢?答案是前端数据劫持。其通过Object.defineProperty()方法,这个方法可以设置getter和setter函数,在setter函数中,就可以监听到数据的变化,从而更新绑定的元素的值。

实现对象属性变化绑定到UI

大概的思路是:

1. 确定绑定的数据,使用Object.defineProperty()对其数据变化进行监听(对应defineGetAndSet)
2. 一旦数据发生改动,会触发setter函数。因此在setter函数内要调用回调函数触发绑定元素的更新。
3. 绑定元素的更新就是遍历所有的绑定元素,通过绑定属性的值确定函数的调用,并传入修改后的值。(对应scan)

实现UI变化绑定到对象属性

这个就比较简单了,因为UI的改变会触发一些事件,比如keyup。通过监听事件来实现数据的改变。而上面说了,数据的改变又会导致绑定其值的元素的UI改变。

实现

var data = {
 value: 'hello world!'
}
var bindValue;
//确定绑定的元素
var bindelems = [document.getElementById('p'), document.getElementById('input')];
//修改绑定元素的值的方法
var command = {
 text: function(str) {
 this.innerHTML = str;
 },
 value: function(str) {
 this.value = str;
 }
};
//遍历绑定元素修改其值
var scan = function() {
 console.log('in scan');
 for(var i = 0; i < bindelems.length; i++) {
 var elem = bindelems[i];
 console.log('elem',elem);
 for(var j = 0; j < elem.attributes.length; j++) {
 var attr = elem.attributes[j];
 if(attr.nodeName.indexOf('q-')>=0) {
 command[attr.nodeName.slice(2)].call(elem, data[attr.nodeValue]);
 }
 }
 }
}
//设置劫持
var defineGetAndSet = function(obj, propname) {
 Object.defineProperty(obj, propname, {
 get: function() {
 return bindValue;
 },
 set: function(value){
 bindValue = value;
 scan();
 },
 enumerable: true,
 configurable: true
 })
} 
//一开始先初始化,使所有绑定的元素值为初始值
scan();
//设置需要被劫持的元素
defineGetAndSet(data, 'value');
//监听UI变化
bindelems[1].addEventListener('keyup', function(e) {
 data.value = e.target.value;
});
setTimeout(function() {
 data.value = 'change';
}, 1000);

参考:

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

Javascript 相关文章推荐
firefox下frameset取不到值的解决方法
Sep 06 Javascript
JSON语法五大要素图文介绍
Dec 04 Javascript
Javasipt:操作radio标签详解
Dec 30 Javascript
js简单实现标签云效果实例
Aug 06 Javascript
最简单纯JavaScript实现Tab标签页切换的方式(推荐)
Jul 25 Javascript
微信小程序 网络API 上传、下载详解
Nov 09 Javascript
关于Sequelize连接查询时inlude中model和association的区别详解
Feb 27 Javascript
JS实现分页浏览横向图片(类轮播)实例代码
Nov 06 Javascript
vue基础之事件v-onclick=&quot;函数&quot;用法示例
Mar 11 Javascript
模块化react-router配置方法详解
Jun 03 Javascript
vue filter 完美时间日期格式的代码
Aug 14 Javascript
Vue自定义组件双向绑定实现原理及方法详解
Sep 03 Javascript
Angular 4.x 路由快速入门学习
May 03 #Javascript
javaScript 逻辑运算符使用技巧整理
May 03 #Javascript
浅谈Node.js轻量级Web框架Express4.x使用指南
May 03 #Javascript
vue的Virtual Dom实现snabbdom解密
May 03 #Javascript
JavaScript中undefined和null的区别
May 03 #Javascript
Node.js对MongoDB数据库实现模糊查询的方法
May 03 #Javascript
xmlplus组件设计系列之文本框(TextBox)(3)
May 03 #Javascript
You might like
PHP 线程安全与非线程安全版本的区别深入解析
2013/08/06 PHP
PHP的数组中提高元素查找与元素去重的效率的技巧解析
2016/03/03 PHP
laravel5.5安装jwt-auth 生成token令牌的示例
2019/10/24 PHP
JavaScript入门教程(12) js对象化编程
2009/01/31 Javascript
SlideView 图片滑动(扩展/收缩)展示效果
2010/08/01 Javascript
JQuery Highcharts 动态生成图表的方法
2013/11/15 Javascript
JS获得图片alt信息的方法
2015/04/01 Javascript
jquery实现隐藏在左侧的弹性弹出菜单效果
2015/09/18 Javascript
JavaScript必知必会(五) eval 的使用
2016/06/08 Javascript
livereload工具实现前端可视化开发【推荐】
2016/12/23 Javascript
JavaScript 栈的详解及实例代码
2017/01/22 Javascript
JavaScript 函数节流详解及方法总结
2017/02/09 Javascript
微信小程序 动态绑定数据及动态事件处理
2017/03/14 Javascript
深入理解Angularjs中$http.post与$.post
2017/05/19 Javascript
JavaScript生成简单等差数列
2017/11/28 Javascript
vue.js element-ui tree树形控件改iview的方法
2018/03/29 Javascript
Vue组件中prop属性使用说明实例代码详解
2018/05/31 Javascript
webpack 开发和生产并行设置的方法
2018/11/08 Javascript
JQuery模拟实现网页中自定义鼠标右键菜单功能
2018/11/14 jQuery
简单了解Vue + ElementUI后台管理模板
2020/04/07 Javascript
react使用CSS实现react动画功能示例
2020/05/18 Javascript
vue3.0封装轮播图组件的步骤
2021/03/04 Vue.js
python+django+sql学生信息管理后台开发
2018/01/11 Python
Python根据服务获取端口号的方法
2019/09/25 Python
Python 实现Serial 与STM32J进行串口通讯
2019/12/18 Python
自定义Django默认的sitemap站点地图样式
2020/03/04 Python
Django Serializer HiddenField隐藏字段实例
2020/03/31 Python
在IE6系列等老式浏览器中使用HTML5的新标签实现方案
2012/12/25 HTML / CSS
解决HTML5手机端页面缩放的问题
2017/10/27 HTML / CSS
趣味活动策划方案
2014/02/08 职场文书
银行委托书范本
2014/04/04 职场文书
电子工程求职信
2014/07/17 职场文书
个人对照检查剖析材料
2014/10/13 职场文书
违反交通安全法检讨书
2014/10/24 职场文书
python通过opencv调用摄像头操作实例分析
2021/06/07 Python
Mybatis-plus配置分页插件返回统一结果集
2022/06/21 Java/Android