vue watch val newval_简易版本vue的实现

65c26ac0eedd15257599876c6d00cf89.png

用了`Vue`也有两年时间了,一直以来都是只知其然,不知其所以然,为了能更好的使用`Vue`不被`Vue`所奴役,学习一下`Vue`底层的基本原理。

`Vue`官网有一段这样的介绍:当你把一个普通的`JavaScript`对象传给`Vue`实例的`data`选项,`Vue`将遍历此对象所有的属性,并使用`Object.defineProperty`把这些属性全部转为`getter/setter`。`Object.defineProperty`是`ES5`中一个无法`shim`的特性,这也就是为什么`Vue`不支持 IE8 以及更低版本浏览器。

通过这一段的介绍不难可以得出,Vue是通过`Object.defineProperty`对实例中的`data`数据做了挟持并且使用`Object.defineProperty`的`getter/setter`并对其进行处理之后完成了数据的与视图的同步。

74fa96bb0af3799171a08885353cda40.png

这张图应该不会很陌生,熟悉`Vue`的同学如果仔细阅读过`Vue`文档的话应该都看到过。猜想一下`Vue`使用`Object.defineProperty`做为`ViewModel`,对数据进行挟持之后如果`View`和`Model`发生变化的话,就会通知其相对应引用的地方进行更新处理,完成视图的与数据的双向绑定。

下面举个例子:

html

<

javaScript

var 

通过上面的代码使用`Object.defineProperty`对`Obj`对象中的`name`属性进行了挟持,一旦该属性发生了变化则会触发`set`函数执行,做出响应的操作。

扯了这么多,具体说一下`Vue`实现的原理。

1. 需要数据监听器`Observer`,能够对数据对象的所有属性进行监听,如有变动可拿到最新值并通知订阅者。

2. 需要指令解析器`Compile`,对每个元素节点的指令进行扫描和解析,根据指令模板替换数据,以及绑定相应的更新函数。

3. 一个`Watcher`,作为连接`Observer`和`Compile`的桥梁,能够订阅并收到每个属性变动的通知,执行指令绑定的相应回调函数,从而更新视图。

4. `MVVM`入口函数,整合以上三者,实现数据响应。

316569e1ed77a03d7e5b6705ca2cf05c.png

接下来的文章将沿着这个思路一步一步向下进行,以便完成一个简单的`Vue`类,完成数据与视图的实时更新。

<

以上代码则是需要完成的功能,保证所有功能全部都能实现。

首先我们要考虑的是,要创建一个`Vue`的类,该类接收的是一个`options`的对象,也就是我们在实例化`Vue`的时候需要传递的参数。

class 

通过上面的代码可以看出了,为什么我们可以在`Vue`实例上通过`this.$data`拿到我们所写的`data`数据。

对数据已经进行了缓存之后,接下来要做的事情就是对数据进行观察,达到数据变化之后能够做出对`虚拟Dom`的操作。

class 

我们对`data`数据中的每一项都进行了数据挟持,可是然而并没有什么卵用啊,我们并没有对相对应的`虚拟dom`进行数据改变,当然我们肯定是不能把我们的需要更改的`虚拟dom`操作写在这里,然而在`Vue`中对其`Dom`进行了特殊的处理,慢慢的向下看。

想要做数据响应要做一个做具体更新的类何以用来管理这些观察者的类

//  管理watcher

`Dep.target = this`上面这段代码一定要注意,是向`Dep`类中添加了一个静态属性。

主要用来解析各种指令,比如`v-modal`,`v-on:click`等指令。然后将模版中的变量替换成数据,渲染`view`,将每个指令对应的节点绑定更新函数,添加监听数据的订阅者,一旦数据发生变动,收到通知,更新视图。

简单说下双向绑定,双向绑定原理,在编译的时候可以解析出v-model在做操作的时候,在使用v-model元素上添加了一个事件监听(input),把事件监听的回调函数作为事件监听的回调函数,如果input发生变化的时候把最新的值设置到vue的实例上,因为vue已经实现了数据的响应化,响应化的set函数会触发界面中所有依赖模块的更新,然后通知哪些model做依赖更新,所以界面中所有跟这个数据有管的东西就更新了。

class 

其实`Compile`整个编译过程,就是在做一个依赖收集的工作,然`Vue`知道每一个指令是做什么的。并做出对应的更新处理。

Vue整体的编译过程,因为vue所编写的指令html无法进行识别,通过编译的过程可以进行依赖收集,依赖收集以后把data中的数据和视图进行了关联,产生了依赖关系,如果以后数据模型发生变化我们可以通过这些依赖通知这些视图进行更新,这是执行编译的目的,就可以做到数据模型驱动视图变化。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值