当前位置: 首页 > news >正文

python底层实现原理_Vue底层实现原理概述

前言

最近在研究 剖析Vue原理&实现双向绑定MVVM 这篇文章,一边学习一边总结一下自己的思考。

Vue是一个典型的MVVM框架,模型(Model)只是普通的JavaScript对象,修改它则视图(View)会自动更新。这种设计让状态管理变得非常简单而直观。那么Vue是如何把模型和视图建立起关联的呢?

实现原理概述

这是前言提到的文章里的代码,一段典型的体现了Vue特点的代码:

{{word}}

change model //点击这个button,word的值会发生改变

var vm = new MVVM({

el: '#mvvm-app',

data: {

word: 'Hello World!'

},

methods: {

sayHi: function() {

this.word = 'Hi, everybody!';

}

}

});

Vue实现这种数据双向绑定的效果,需要三大模块:

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

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

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

Observer

Observer的核心是通过Obeject.defineProperty()来监听数据的变动,这个函数内部可以定义setter和getter,每当数据发生变化,就会触发setter。这时候Observer就要通知订阅者,订阅者就是Watcher。

Watcher

Watcher订阅者作为Observer和Compile之间通信的桥梁,主要做的事情是:

在自身实例化时往属性订阅器(dep)里面添加自己

自身必须有一个update()方法

待属性变动dep.notice()通知时,能调用自身的update()方法,并触发Compile中绑定的回调

Compile

Compile主要做的事情是解析模板指令,将模板中的变量替换成数据,然后初始化渲染页面视图,并将每个指令对应的节点绑定更新函数,添加监听数据的订阅者,一旦数据有变动,收到通知,更新视图。

总结

关于每部分具体的代码实现,可以参阅 剖析Vue原理&实现双向绑定MVVM 这篇文章,这篇文章写得非常好。我打算研究透彻之后自己实现一下简易的Vue框架。

相关文章:

  • layui后台模板_基于SpringBoot+Mybatis+Vue搭建后台管理模板框架,CRUD源码分享
  • 怎么在ubuntu上运行python_ubuntu怎么运行python
  • python判断图片相似度_opencv+python用直方图进行相似度判断、对比
  • python发送qq邮件_python实现QQ邮箱发送邮件
  • html开关_用树莓派DIY“啪啪”声控开关
  • python练习项目_python练习项目
  • java程序员修炼之道 pdf_《程序员修炼之道(第2版)》到货!屹立20年影响力大作归来!...
  • python读取特定两列_如何基于python中的where函数获取两列值
  • python人工智能框架有哪些_10个最佳的人工智能开发框架和AI库
  • python2md5迁移_Python远程获取MD5校验码并在web上显示
  • 同一个socket收发顺序_Kafka-“高吞吐”-之顺序访问与零拷贝
  • h5汽车图片标注鼠标经过提示_学用系列|尝鲜基于H5技术的交互式科学公示编辑器——BOOM DOCS...
  • python批处理文件_python实现批处理文件
  • python列表快速排序_快速排序的四种python实现(推荐)
  • python3.5升级_macos10.12 升级到最新的python3.5环境
  • 2017-08-04 前端日报
  • 2017前端实习生面试总结
  • dva中组件的懒加载
  • java B2B2C 源码多租户电子商城系统-Kafka基本使用介绍
  • react-native 安卓真机环境搭建
  • 大整数乘法-表格法
  • 回流、重绘及其优化
  • 开源地图数据可视化库——mapnik
  • 前端代码风格自动化系列(二)之Commitlint
  • 前端技术周刊 2019-01-14:客户端存储
  • 我的业余项目总结
  • 写给高年级小学生看的《Bash 指南》
  • python最赚钱的4个方向,你最心动的是哪个?
  • ​LeetCode解法汇总2696. 删除子串后的字符串最小长度
  • #绘制圆心_R语言——绘制一个诚意满满的圆 祝你2021圆圆满满
  • (C语言)字符分类函数
  • (MATLAB)第五章-矩阵运算
  • (二十五)admin-boot项目之集成消息队列Rabbitmq
  • (附源码)python旅游推荐系统 毕业设计 250623
  • (附源码)springboot猪场管理系统 毕业设计 160901
  • (转)IIS6 ASP 0251超过响应缓冲区限制错误的解决方法
  • (转)jdk与jre的区别
  • .libPaths()设置包加载目录
  • .NET 4.0中使用内存映射文件实现进程通讯
  • .NET Reactor简单使用教程
  • .Net Remoting常用部署结构
  • .NET 线程 Thread 进程 Process、线程池 pool、Invoke、begininvoke、异步回调
  • .Net 转战 Android 4.4 日常笔记(4)--按钮事件和国际化
  • .NET4.0并行计算技术基础(1)
  • .net开源工作流引擎ccflow表单数据返回值Pop分组模式和表格模式对比
  • .net之微信企业号开发(一) 所使用的环境与工具以及准备工作
  • @ModelAttribute使用详解
  • @RestController注解的使用
  • @TableId注解详细介绍 mybaits 实体类主键注解
  • [3300万人的聊天室] 作为产品的上游公司该如何?
  • [3D基础]理解计算机3D图形学中的坐标系变换
  • [Android] 240204批量生成联系人,短信,通话记录的APK
  • [bzoj4240] 有趣的家庭菜园
  • [C#]使用PaddleInference图片旋转四种角度检测
  • [C++]Leetcode17电话号码的字母组合