vue 双向数据绑定的实现原理

在目前市场应用比较火的前端框架中,我个人很喜欢vue,总结了vue的几大特点:(1) 简洁 (2) 轻量 (3)快速 (4) 数据驱动 (5) 模块友好 (6) 组件化
vue在使用过程中如此便捷就主要源于它的双向数据流,那么它是如何实现的?用简短的代码演示一下vue双向数据绑定的原理便一目了然:

  • 用Object的defindProperty方法。基于访问器属性get set实现。
<input type="text" id="a"/>
<span id="b"></span>
//js 模拟实现双向数据绑定效果
let obj = {};
let val = '';
Object.defineProperty(obj,'val',{
  get:function(){ //获取值
    return val
  },
  set:function(newValue){  //设置值
    val = newValue;
    document.getElementById('b').innerHTML = val
  }
})
//监听数据改变的事件
document.addEventListener('keyup',function(e){
  obj.val = e.target.value;
})

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值