MVC架构

MVC架构

为什么要关注架构?

  • 架构

就像房子一样,软件也需要一个结构: 这是我们组织代码的方式;

  • 可维护性

项目永远没有终点!我们需要能够在未来轻松地对其进行修改。

  • 可扩展性

我们还需要可以轻松的添加新功能

在构建完美的架构时,我们有以下几种选择:

  1. 自定义架构(比如Mapty项目):我们可以根据项目的具体需求,设计并实现一个完全自定义的架构。这种方式提供了最大的灵活性,但同时也需要更多的开发事件和资源来确保架构的稳定性和可维护性;
  2. 使用成熟的架构模式(如MVC、MVP、Flux等):这些架构模式已经被广泛验证,能够提供良好的结构化和模块化。使用这些模式可以加快开发速度,减少错误,并且更容易维护和扩展;
  3. 使用框架(比如React、VUE、Angular、Svelte等):这些前端框架提供了丰富的功能和工具,能够极大地简化开发过程。它们通常内置了最佳实践和架构模式,使得开发者可以专注于业务逻辑的实现,而不必过多担心底层架构的设计。选择哪种方式取决于项目的具体需求、团队的技能水平以及事件和资源的限制。无论选择哪种方式,目标都是构建一个可扩展、可维护且高效的架构;

任何架构的组成部分

  1. 业务逻辑
  • 解决实际业务问题的代码;
  • 与企业做什么和需要什么直接相关
  • 例如: 发送消息、存储交易、计算税费、用于身份验证等等;
  1. 状态
  • 实质上存储有关应用程序的所有数据;
  • 应该是"单一事实来源";
  • UI应与状态保持同步;
  • 存在状态库,例如Redux、MobX;
  1. HTTP库
  • 负责发送和接受AJAX请求;
  • 在实际应用中虽然不是必须的,但是几乎总是必要的;
  1. 应用逻辑(ROUTER)
  • 只关注应用程序本身实现的代码;
  • 处理导航和UI事件;
  1. 表示逻辑(UI层)
  • 关注应用程序可见部分的代码;
  • 本质上显示应用程序的状态;

模型-视图-控制器(MVC)架构

  1. MODEL
  • 业务逻辑
  • 状态
  • HTTP库
  1. CONTROLLER
  • 应用逻辑
    • 模型和视图之间的桥梁(两者彼此不知晓);
    • 处理UI事件并将任务分派给模型和视图;
  1. view
  • 表示逻辑

工作流程

  1. 用户与view交互(比如点击按钮)。
  2. View将用户操作传递给Controller。
  3. Controller处理请求,调用Model更新数据或执行逻辑。
  4. Model更新数据并返回结果给Controller.
  5. Controller更新View以反映新的数据状态。
  6. 用户看到更新后的View

MVC实现(仅用于食谱展示)

相关推荐
安心不心安13 分钟前
React hooks——useReducer
前端·javascript·react.js
像风一样自由202014 分钟前
原生前端JavaScript/CSS与现代框架(Vue、React)的联系与区别(详细版)
前端·javascript·css
啃火龙果的兔子15 分钟前
react19+nextjs+antd切换主题颜色
前端·javascript·react.js
_pengliang22 分钟前
小程序按住说话
开发语言·javascript·小程序
布兰妮甜23 分钟前
创建游戏或互动体验:从概念到实现的完整指南
javascript·游戏开发·游戏ai·互动体验·用户输入处理
秋千码途34 分钟前
小架构step系列17:getter-setter-toString
java·开发语言·架构
Ashlee_code1 小时前
美联储降息趋缓叠加能源需求下调,泰国证券交易所新一代交易系统架构方案——高合规、强韧性、本地化的跨境金融基础设施解决方案
java·算法·金融·架构·系统架构·区块链·需求分析
zkmall2 小时前
ZKmall开源商城架构助力增长:多端流量聚合与用户体验
架构·开源·ux
小飞悟2 小时前
JavaScript 数组精讲:创建与遍历全解析
前端·javascript
喝拿铁写前端2 小时前
技术是决策与代价的平衡 —— 超大系统从 Vue 2 向 Vue 3 演进的思考
前端·vue.js·架构