【vue】vue中数据双向绑定原理/响应式原理,mvvm,mvc、mvp分别是什么
关于 vue 的原理主要有两个重要内容,分别是 mvvm 数据双向绑定原理,和 响应式原理
MVC(Model-View-Controller):
- Model(模型):表示应用程序的数据和业务逻辑。
- View(视图):负责展示数据给用户,并且接受用户的输入。
- Controller(控制器):负责处理用户的输入和操作,当用户与页面产生交互的时候开始工作,然后调用model 层修改model
- view 和 model 应用了观察者模式,当 model 层发生改变的时候它会通知有关的view 层更新
- 【箭头方向统一的三角形】
- view -> controller ->model -> view
- 缺点:view 层和 model 层 耦合在一起,当项目逻辑复杂是,会造成代码混乱。
MVP(Model-View-Presenter):
- Model(模型):同样表示应用程序的数据和业务逻辑。
- View(视图):负责展示数据给用户,并且接受用户的输入。
- Presenter(主持人):将 model 的变化和view 的变化绑定在一起,(1) 实现 view 和 model 同步更新,(2) 实现 view 和 model 的解藕,还包含了其他的响应逻辑
- view -> presenter
- presenter -> view
- presenter -> model【没有model-presenter 的箭头】
MVVM(Model-View-ViewModel):
- Model(模型):同样表示应用程序的数据和业务逻辑。
- View(视图):负责展示数据给用户,并且接受用户的输入。
- ViewModel(视图模型):负责将模型的数据转换为视图所需的格式,并且处理视图的用户交互。视图模型通过数据绑定与视图进行连接。
- MVVM 模式通常利用双向数据绑定来实现视图和视图模型之间的通信。
- 思想和 mvp 是相同的,不过通过双向数据绑定,将 view 和model 的同步更新自动化了。
- model 发生变化,viewmodel 会自动更新
- viewmodel 变化了, view 也会自动更新
vue 中 mvvm 数据双向绑定原理/响应式原理
本质【数据劫持】+【发布订阅模式】
注意【发布订阅模式】和【观察者模式】是有区别的
- 数据劫持 Observer
- vue2 使用 Object.definedProperty
- vue3 使用 proxy
- 第一步,就是把所有的变量变成响应式对象,都能够触发对应的 getter 和 setter
- vue 会创建一个 dep 对象,存储当前属性的所有 watcher 对象【dep 类似于发布订阅中的那个存储所有事件的数组】【watcher 对象类似于发布订阅中的事件名称】
- 【依赖收集】当属性的 getter 被访问时,watcher 对象将会被添加到 dep 中【相当于订阅发布中的 on 方法】
- 当属性的 setter 被调用时,dep 中所有 watcher 对象将会被通知执行更新【相当于发布订阅中的 emit 方法】
- 在数据劫持的步骤进行依赖收集
- observer 监听自己的 model 数据变化
- compile 模版编译
- 将vue模版编译成渲染函数【h 函数】
- vue 将模版中的数据绑定语法(如 {{}} 和 v-model)转换为对数据的 getter/setter 的调用
- 对每个指令对应的节点绑定更新函数【相当于发布订阅中的回调函数】
- 添加监听数据的订阅者,数据变动时,收到通知,更新视图
- Watcher 监听器
- 对应发布/订阅模式中的订阅者【就是 on(''change-name", fn) 中的 change-name这个方法】
- 在自身实例化时往属性订阅器 dep 里添加自己
- 自身有一个更新函数
- dep.notice 通知时,调用自身的 update 方法,并触发 compile绑定的回调
- 利用 watcher 搭起 observer 和 compile 之间的通信桥梁
- 达到 数据变化 -> 视图更新,视图交互变化-> 数据 model 变化的双向绑定效果
相关文章:
【vue】vue中数据双向绑定原理/响应式原理,mvvm,mvc、mvp分别是什么
关于 vue 的原理主要有两个重要内容,分别是 mvvm 数据双向绑定原理,和 响应式原理 MVC(Model-View-Controller): Model(模型):表示应用程序的数据和业务逻辑。View(视图&…...
基于反光柱特征的激光定位算法思路
目录 1. 识别反光柱2. 数据关联2.1 基于几何形状寻找匹配2.2 暴力寻找匹配 3. 位姿估计(最小二乘求解)4. 问题4.1 精度问题4.2 快速旋转时定位较差 1. 识别反光柱 反光柱是特殊材料制成,根据激光雷达对反光材料扫描得到的反射值来提取特征。…...
CSM是什么意思?
CSM(Customer Service Management)是企业客户服务管理的信息化(IT)解决方案架构。本着以客户为中心的管理理念,搭建企业客户服务管理平台,实现企业以客户为中心的管理时代的竞争战略。 CSM的核心是以客户为中心,实现对…...
ES6 面试题
1. const、let 和 var 的区别是什么? 答案: var 声明的变量是函数作用域或全局作用域,而 const 和 let 声明的变量是块级作用域。使用 var 声明的变量可以被重复声明,而 const 和 let 不允许重复声明同一变量。const 声明的变量…...
智能指针(C++)
目录 一、智能指针是什么 二、为什么需要智能指针 三、智能指针的使用和原理 3.1、RALL 3.2 智能指针的原理 3.3、智能指针的分类 3.3.1、auto_ptr 3.3.2、unique_ptr 3.3.3、shared_ptr 3.2.4、weak_ptr 一、智能指针是什么 在c中,动态内存的管理式通过一…...
社区店商业模式探讨:如何创新并持续盈利?
在竞争激烈的商业环境中,社区店要想获得成功并持续盈利,需要不断创新和优化商业模式。 作为一名开鲜奶吧5年的创业者,我将分享一些关于社区店商业模式创新的干货和见解,希望能给想开实体店或创业的朋友们提供有价值的参考。 1、…...
一些可以访问gpt的方式
1、Coze扣子是新一代 AI 大模型智能体开发平台。整合了插件、长短期记忆、工作流、卡片等丰富能力,扣子能帮你低门槛、快速搭建个性化或具备商业价值的智能体,并发布到豆包、飞书等各个平台。https://www.coze.cn/ 2、https://poe.com/ 3、插件阿里…...
springer模板参考文献不显示
Spring期刊模板网站,我的问题是23年12月的版本 https://www.springernature.com/gp/authors/campaigns/latex-author-support/see-where-our-services-will-take-you/18782940 参考文献显示问好,在sn-article.tex文件中,这个sn-mathphys-num…...
【【C语言简单小题学习-1】】
实现九九乘法表 // 输出乘法口诀表 int main() {int i 0;int j 0;for (i 1; i < 9; i){for (j 1; j < i;j)printf("%d*%d%d ", i , j, i*j);printf("\n"); }return 0; }猜数字的游戏设计 #define _CRT_SECURE_NO_WARNINGS 1 #include<stdi…...
mongoDB 优化(1)索引
1、创建复合索引(多字段) db.collection_test1.createIndex({deletedVersion: 1,param: 1,qrYearMonth: 1},{name: "deletedVersion_1_param_1_qrYearMonth_1",background: true} ); 2、新增索引前: 执行查询: mb.r…...
stable diffusion webUI之赛博菩萨【秋葉】——工具包新手安裝与使用教程
stable diffusion webUI之赛博菩萨【秋葉】——工具包新手安裝与使用教程 AI浪潮袭来,还是学习学习为妙赛博菩萨【秋葉】简介——(葉ye,四声,同叶)A绘世启动器.exe(sd-webui-aki-v4.6.x)工具包安…...
鸿蒙应用程序包安装和卸载流程
开发者 开发者可以通过调试命令进行应用的安装和卸载,可参考多HAP的调试流程。 图1 应用程序包安装和卸载流程(开发者) 多HAP的开发调试与发布部署流程 多HAP的开发调试与发布部署流程如下图所示。 图1 多HAP的开发调试与发布部署流程 …...
C语言数组全面解析:从初学到精通
数组 1. 前言2. 一维数组的创建和初始化3. 一维数组的使用4. 一维数组在内存中的存储5. 二维数组的创建和初始化6. 二维数组的使用7. 二维数组在内存中的存储8. 数组越界9. 数组作为函数参数10. 综合练习10.1 用函数初始化,逆置,打印整型数组10.2 交换两…...
2024-02-28(Kafka,Oozie,Flink)
1.Kafka的数据存储形式 一个主题由多个分区组成 一个分区由多个segment段组成 一个segment段由多个文件组成(log,index(稀疏索引),timeindex(根据时间做的索引)) 2.读数据的流程 …...
Window下编写的sh文件在Linux/Docker中无法使用
Window下编写的sh文件在Linux/Docker中无法使用 一、sh文件目的1.1 初始状态1.2 目的 二、过程与异常2.1 首先获取标准ubuntu20.04 - 正常2.2 启动ubuntu20.04容器 - 正常2.3 执行windows下写的preInstall文件 - 报错 三、检查和处理3.1 评估异常3.2 处理异常3.3 调整后运行测试…...
第16章-DNS
目录 1. 域名 1.1 产生背景 1.2 概述 1.3 域名的树形层次化结构 2. DNS 2.1 概述 2.2 工作机制 3. DNS查询模式 3.1 递归查询: 3.2 迭代查询: 4. 相关知识点 4.1 集中式DNS 4.2 国内通用DNS 4.3 配置DNS代理 1. 域名 1.1 产生背景 ① IP…...
Leetcoder Day27| 贪心算法part01
语言:Java/Go 理论 贪心的本质是选择每一阶段的局部最优,从而达到全局最优。 什么时候用贪心?可以用局部最优退出全局最优,并且想不到反例到情况 贪心的一般解题步骤 将问题分解为若干个子问题找出适合的贪心策略求解每一个子…...
SpringBoot自动配置中bean的加载控制
🙈作者简介:练习时长两年半的Java up主 🙉个人主页:程序员老茶 🙊 ps:点赞👍是免费的,却可以让写博客的作者开心好久好久😎 📚系列专栏:Java全栈,…...
Linux系统运维脚本:根据菜单选择要登录到的Linux主机,方便维护多个linux服务器
目 录 一、要求 二、解决方案 (一)解决思路 (二)方案 三、脚本程序实现 (一)脚本代码和解释 1、定义hosts.txt文件 2、脚本代码 3、代码解释 (二)脚本验证 1…...
蓝桥杯练习题——二分
1.借教室 思路 1.随着订单的增加,每天可用的教室越来越少,二分查找最后一个教室没有出现负数的订单编号 2.每个订单的操作是 [s, t] 全部减去 d #include<iostream> #include<cstring> using namespace std; const int N 1e6 10; int d[…...
终极指南:3分钟学会用Ofd2Pdf免费实现OFD到PDF无损转换
终极指南:3分钟学会用Ofd2Pdf免费实现OFD到PDF无损转换 【免费下载链接】Ofd2Pdf Convert OFD files to PDF files. 项目地址: https://gitcode.com/gh_mirrors/ofd/Ofd2Pdf Ofd2Pdf是一款专为中国用户设计的开源工具,能够快速、无损地将OFD格式电…...
SeqGPT-560M命名实体识别效果展示:精准抽取各类实体
SeqGPT-560M命名实体识别效果展示:精准抽取各类实体 1. 开篇:当AI成为信息提取的"火眼金睛" 你有没有遇到过这样的情况:面对一篇长篇报告,需要快速找出所有人名、地名和机构名;或者处理大量新闻稿件时&…...
终极指南:3步快速修复Kindle电子书封面不显示问题
终极指南:3步快速修复Kindle电子书封面不显示问题 【免费下载链接】Fix-Kindle-Ebook-Cover A tool to fix damaged cover of Kindle ebook. 项目地址: https://gitcode.com/gh_mirrors/fi/Fix-Kindle-Ebook-Cover Kindle电子书封面不显示是许多读者都会遇到…...
formsy-react跨字段验证:实现复杂业务逻辑的终极方法
formsy-react跨字段验证:实现复杂业务逻辑的终极方法 【免费下载链接】formsy-react A form input builder and validator for React JS 项目地址: https://gitcode.com/gh_mirrors/fo/formsy-react 想要在React应用中构建复杂的表单验证逻辑吗?f…...
探索MuJoCo视觉抓取强化学习:从零开始的智能机器人控制实战指南
探索MuJoCo视觉抓取强化学习:从零开始的智能机器人控制实战指南 【免费下载链接】MuJoCo_RL_UR5 A MuJoCo/Gym environment for robot control using Reinforcement Learning. The task of agents in this environment is pixel-wise prediction of grasp success c…...
火灾后的建筑残骸、燃烧痕迹的光学三维扫描测量逆向-激光三维扫描仪
摘要火灾后的建筑残骸形态、燃烧痕迹分布是事故原因追溯、责任认定及灾后重建的核心依据,其现场易破坏、结构不稳定特性对测量技术提出非接触、快速、高精度要求。激光三维扫描仪依托光学三维扫描测量逆向技术,实现建筑残骸结构、燃烧轨迹的数字化复刻与…...
Kook Zimage真实幻想Turbo保姆级教学:WebUI历史记录导出与管理
Kook Zimage真实幻想Turbo保姆级教学:WebUI历史记录导出与管理 1. 项目简介 Kook Zimage真实幻想Turbo是一款专为个人GPU设计的轻量化幻想风格文本生成图像系统。基于Z-Image-Turbo官方极速文生图底座,通过自定义权重清洗与非严格注入方式,…...
OpenClaw资源监控:Qwen3.5-9B预警系统异常与自动处理
OpenClaw资源监控:Qwen3.5-9B预警系统异常与自动处理 1. 为什么需要智能化的资源监控 去年夏天,我的开发机因为磁盘写满导致线上服务日志无法写入,造成了整整两小时的服务中断。这件事让我意识到:传统的监控告警系统存在两个致命…...
掼蛋开源项目
掼蛋开源项目,纯娱乐,支持单机模式,AI智能程度还是可以的。欢迎来学习交流,能给个Star最好了,感谢~ 代码仓库...
# MyBatis Mapper文件不想手动注册?启动时自动扫描conf目录,动态拼配置
MyBatis Mapper文件不想手动注册?启动时自动扫描conf目录,动态拼配置 非科班野生程序员,深耕政务信息化20年。从VC到PB再到Java,自研框架browise也打磨了十几年。最近整理框架代码,发现不少有趣的决策,写出…...
