资讯专栏INFORMATION COLUMN

订阅发布和vue双向绑定

Joyven / 1651人阅读

摘要:概念理解重要特性双向绑定和之间无耦合通过操作利用提供的机制自动实现的更新。实现说明解析不包括模板指令等因为模板编译解析等和本文核心主题无关这些仅仅是基于双向绑定的应用场景。双向绑定的核心是实现。

引言

最近在看vue的源码,有些感触,下面阐述一些个人理解。
之前写过一篇文章,是讲述关于观察者模式的,与本文主旨有关,需要的朋友可以看一下。

vue的核心是mvvm,vue2又增加了虚拟dom。
我的研究方向也是以这两个为主。
本文主要讲述mvvm,至于vdom(主要研究方向是整个思想和diff算法)下次再论述。

mvvm概念理解

m(model)v(view)vm(view-model),重要特性双向绑定,m和v之间无耦合,通过操作m,利用vm提供的机制,自动实现v的更新。用过vue应该会有较深体会。

和其相对比比较容易误解是mvc,m(model)v(view)c(controller),和mvvm的显著区别是m和v之间存在耦合,业务逻辑集中在c当中。 用过springmvc应该会有体会。

mvvm实现

说明 解析不包括模板、指令、Mustache等,因为模板编译、解析等和本文核心主题无关,这些仅仅是基于双向绑定的应用场景。本文主题想讨论的是->结合观察者模式简单实现双向绑定的核心。

双向绑定的核心是实现Dep、observer、Watcher。

Dep 存放收集Watcher,当订阅的消息发生时(即数据发生改变),notify所有watch,让订阅者执行实现自己定义的update逻辑

Watcher 转化表达式,收集依赖,当被观察的值发生变化时,触发callback。重要update方法,当model数据发生变化时,修改依赖指令或组件中的值,触发callback函数

observer 是一个类,附属于每一个被观察的对象(即model数据),defineReactive=>observe方式给对象以及子属性(实质调用defineProperty方式)建立get和set属性方法

结合下图,以便于大致理解。

关于其执行流程具体如下,上述示例图中画的其实也只是大致流程,实现过程中有很多细节,列举几个我认为比较重要的。

this.get()执行的时候,会把Dep的全局tatget对象置为当前对象,而data的get方法以此作为judge调用者依据,从而完成依赖收集,收集完cleanupDeps,将其置空,以免影响下次收集。

当data持续变化时,queueWatcher中has[id]的judge防止watcher重复添加,nextTick的使用保证view更新时使用的最新值,异步的应用有三种实现方式(兼容性考虑),基于优先级顺序依次是Promise、MutationObserver、setTimeout。

data变化,view更新的实现是通过notify->run-> expOrFn.call(vm,vm)->vm._update(vnode, hydrating)->vm.__patch__(prevVnode, vnode)一系列调用过程实现。

观察者体现

至于观察者模式是如何在其中体现呢?

observer和Watcher是一对多的关系,连接机制通过dep(其中注册了一些观察者), 消息触发根源是user,其行为导致model改变,被观察者(data)进行notify, 具体订阅者watcher执行自己预先定义好的update逻辑。

整个过程很好的体现了注册-通知的机制。

总结

这篇文章分析基于Vue(Version 2.2.6),示例中图画的丑,画图真心不易。个人观点,如有不同理解,欢迎comment。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/82649.html

相关文章

  • Vue源码解析(二)Vue双向绑定讲解及实现

    摘要:上篇文章,我们讲解了的属性映射和方法的重定义,链接地址如下源码解析一属性映射和函数引用的重定义这篇文章给大家带来的是的双向绑定讲解。这就是的双向绑定。使用定时器定时检查的值,发生变化就通知订阅者。这个方法不好,定时器不能实时反应变化。 文章中的代码时阶段,可以下载源码测试一下。git项目地址:https://github.com/xubaodian/...项目使用webpack构建,下...

    ckllj 评论0 收藏0
  • 160行代码仿Vue实现极简双向绑定[详细注释]

    摘要:兼容性更详细的可以看一下实现思路系列的双向绑定,关键步骤实现数据监听器,用重写数据的,值更新就在中通知订阅者更新数据。 showImg(https://segmentfault.com/img/remote/1460000015375220?w=640&h=426); 前言 现在的前端面试不管你用的什么框架,总会问你这个框架的双向绑定机制,有的甚至要求你现场实现一个双向绑定出来,那对于...

    endiat 评论0 收藏0
  • vue 双向数据绑定的实现学习(一)

    摘要:双向数据绑定简言之数据动页面动,页面动,数据动典型的应用就是在做表单时候,输入框的内容改动后,跟该输入框的的值改动。看官网上的这个的演示案例双向数据绑定的好处要说出这个好处的时候,也只有在实际场景中才能对应的显示出来。 前言:本系列学习笔记从以下几个点展开 什么是双向数据绑定 双向数据绑定的好处 怎么实现双向数据绑定 实现双向数据数据绑定需要哪些知识点 数据劫持 发布订阅模式 ...

    anonymoussf 评论0 收藏0
  • Vue面试题精选:Vue原理以及双向数据绑定的实战过程

    摘要:双向数据绑定指的是,将对象属性变化与视图的变化相互绑定。数据双向绑定已经了解到是通过数据劫持的方式来做数据绑定的,其中最核心的方法便是通过来实现对属性的劫持,达到监听数据变动的目的。和允许观察数据的更改并触发更新。 1 MVVM 双向数据绑定指的是,将对象属性变化与视图的变化相互绑定。换句话说,如果有一个拥有name属性的user对象,与元素的内容绑定,当给user.name赋予一个新...

    malakashi 评论0 收藏0

发表评论

0条评论

Joyven

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<