全网整合营销服务商

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

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

Vue实现双向数据绑定

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实现数据双向绑定的三种方式

剖析Vue原理&实现双向绑定MVVM

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


# Vue  # 数据绑定  # 详解Vue双向数据绑定原理解析  # 轻松理解vue的双向数据绑定问题  # vue双向数据绑定原理探究(附demo)  # Vue.js实现双向数据绑定方法(表单自动赋值、表单自动取值)  # 使用Vue如何写一个双向数据绑定(面试常见)  # 通过源码分析Vue的双向数据绑定详解  # vue双向数据绑定知识点总结  # vue实现的双向数据绑定操作示例  # vue 双向数据绑定的实现学习之监听器的实现方法  # vue.js使用v-model实现表单元素(input) 双向数据绑定功能示例  # 绑定  # 遍历  # 说了  # 对其  # 三种  # 又会  # 来实现  # 回调  # 具体内容  # 值为  # 大家多多  # 如何实现  # 就可以  # 被劫  # pre  # class  # brush  # var  # strong 


相关文章: 建站之星北京办公室:智能建站系统与小程序生成方案解析  建站之星如何保障用户数据免受黑客入侵?  上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?  相册网站制作软件,图片上的网址怎么复制?  广州美橙建站如何快速搭建多端合一网站?  建站主机选购指南:核心配置优化与品牌推荐方案  如何制作一个表白网站视频,关于勇敢表白的小标题?  建站之星24小时客服电话如何获取?  公司网站设计制作厂家,怎么创建自己的一个网站?  大连网站设计制作招聘信息,大连投诉网站有哪些?  如何选择高效便捷的WAP商城建站系统?  建站之星伪静态规则如何正确配置?  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  建站主机选哪种环境更利于SEO优化?  湖北网站制作公司有哪些,湖北清能集团官网?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  已有域名能否直接搭建网站?  微课制作网站有哪些,微课网怎么进?  深圳 网站制作,深圳招聘网站哪个比较好一点啊?  建站之星免费版是否永久可用?  IOS倒计时设置UIButton标题title的抖动问题  建站之星图片链接生成指南:自助建站与智能设计教程  如何在阿里云虚拟服务器快速搭建网站?  自助网站制作软件,个人如何自助建网站?  如何选择高性价比服务器搭建个人网站?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  红河网站制作公司,红河事业单位身份证如何上传?  如何快速搭建FTP站点实现文件共享?  枣阳网站制作,阳新火车站打的到仙岛湖多少钱?  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  如何打造高效商业网站?建站目的决定转化率  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  如何在搬瓦工VPS快速搭建网站?  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  如何通过虚拟主机快速完成网站搭建?  较简单的网站制作软件有哪些,手机版网页制作用什么软件?  独立制作一个网站多少钱,建立网站需要花多少钱?  建站之星导航如何优化提升用户体验?  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  全景视频制作网站有哪些,全景图怎么做成网页?  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  如何选择适配移动端的WAP自助建站平台?  如何使用Golang table-driven基准测试_多组数据测量函数效率  代刷网站制作软件,别人代刷火车票靠谱吗?  实现点击下箭头变上箭头来回切换的两种方法【推荐】  如何用美橙互联一键搭建多站合一网站?  建站之星代理平台如何选择最佳方案?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  建站主机类型有哪些?如何正确选型 

您的项目需求

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