【Vue全家桶】声明式编程、MVVM
创始人
2025-05-30 17:53:30
0

【Vue全家桶】声明式编程、MVVM

文章目录

  • 【Vue全家桶】声明式编程、MVVM
  • 写在前面
  • 一、声明式编程与命令式编程
    • 1.1 原生方法实现
    • 1.2 Vue实现
    • 1.3 声明式和命令式编程
  • 二、MVVM、MVC的区别
    • 2.1 MVC
    • 2.2 MVVM

写在前面

这里是前端程序员小张🫡

创作不易,希望各位大佬支持一下🌟

一、声明式编程与命令式编程

1.1 原生方法实现

计数器原生实现

// 1.获取对应的dom
const counterEl = document.querySelector(".counter")
const addBtn = document.querySelector(".add")
const subBtn = document.querySelector(".sub")// 2.定义变量记录数据
let counter = 0
counterEl.textContent = counter// 3.监听按钮的点击
addBtn.onclick = function () {counter++counterEl.textContent = counter
}subBtn.onclick = function () {counter--counterEl.textContent = counter
}

1.2 Vue实现

Vue实现

当前数字:{{counter}}

const app = Vue.createApp({data: function () {return {counter: 0}},methods: {add: function () {this.counter++},sub: function () {this.counter--}}
}).mount("#app")

1.3 声明式和命令式编程

  • 原生开发和Vue开发的模式和特点,我们会发现是完全不同的,这里其实涉及到两种不同的编程范式
    • 命令式编程和声明式编程;
    • 命令式编程关注的是 “how to do”自己完成整个how的过程;
    • 声明式编程关注的是 “what to do”,由框架完成 “how”的过程;
  • 在原生的实现过程中,我们是如何操作的呢
    • 我们每完成一个操作,都需要通过JavaScript编写一条代码,来给浏览器一个指令;
    • 这样的编写代码的过程,我们称之为命令式编程;
    • 在早期的原生JavaScript和jQuery开发的过程中,我们都是通过这种命令式的方式在编写代码的;
  • 在Vue的实现过程中,我们是如何操作的呢
    • 我们会在createApp传入的对象中声明需要的内容,模板template、数据data、方法methods;
    • 这样的编写代码的过程,我们称之为是声明式编程
    • 目前Vue、React、Angular、小程序的编程模式,我们称之为声明式编程;

二、MVVM、MVC的区别

MVC、MVP 和 MVVM 是三种常见的软件架构设计模式,主要通过分离关注点的方式来组织代码结构,优化开发效率。

在开发单页面应用时,往往一个路由页面对应了一个脚本文件,所有的页面逻辑都在一个脚本文件里。页面的渲染、数据的获取,对用户事件的响应所有的应用逻辑都混合在一起,这样在开发简单项目时,可能看不出什么问题,如果项目变得复杂,那么整个文件就会变得冗长、混乱,这样对项目开发和后期的项目维护是非常不利的。

2.1 MVC

  • MVC 通过分离 Model、View 和 Controller 的方式来组织代码结构。
  • 其中 View 负责页面的显示逻辑,Model 负责存储页面的业务数据,以及对相应数据的操作。
  • 并且 View 和 Model 应用了观察者模式,当 Model 层发生改变的时候它会通知有关 View 层更新页面。
  • Controller 层是 View 层和 Model 层的纽带,它主要负责用户与应用的响应操作,当用户与页面产生交互的时候,Controller 中的事件触发器就开始工作了,通过调用 Model 层,来完成对 Model 的修改,然后 Model 层再去通知 View 层更新

在这里插入图片描述

2.2 MVVM

MVVM 分为 Model、View、ViewModel:

  • Model代表数据模型,数据和业务逻辑都在Model层中定义;
  • View代表UI视图,负责数据的展示;
  • ViewModel负责监听Model中数据的改变并且控制视图的更新,处理用户交互操作;

Model和View并无直接关联,而是通过ViewModel来进行联系的,Model和ViewModel之间有着双向数据绑定的联系。因此当Model中的数据改变时会触发View层的刷新,View中由于用户交互操作而改变的数据也会在Model中同步。

这种模式实现了 Model和View的数据自动同步,因此开发者只需要专注于数据的维护操作即可,而不需要自己操作DOM。
在这里插入图片描述

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...