前端设计模式之 MPVC Part 3
本篇主要介绍 MPVC 中的关键组件:
Pagelet
页面消息的包装类,里面包含更新视图的所需要的信息:Html 代码,插入位置,额外的 Json 数据参考等信息。
一个 Pagelet 对应一个前端的构建块,Pagelet 的作用包括:
- 添加、修改构建块
- 删除构建块
- 向构建块发送 Json 消息
PageletProcessor
解析 Pagelet 里面的信息,并进行处理,完成视图更新。
NavigationManager
处理虚拟页面切换,并管理 Url 历史。
加载一个新页面,可以理解为在一个特定区域内加载一个页面级的 Pagelet,并将原来的页面实例 Dispose 掉。
在查看列表类页面时,列表页面不会因为详细页的对象加载而消息失,而是仅仅隐藏起来并且可以由特别的条件激活,比如 Backspace 或者某个特别的元素点击事件。
NavigationManager 理论上将所有的页面跳转换为 Pagelet 消息加载和处理,达到无刷新的效果。
ClassRegister
为了根据构建块的类型创建它的实例,需要一种类似于 "反射" 的机制来取得目标类型的构造函数或工厂方法,ClassRegister 提供类型字符串到构造函数的映射关系。
页面在构建时的流程
后台在生成页面时,同时生成一个有层次关系的 Map,里面包含了各构建块的父子关系。页面到达客户端之后,从根节点开始,根据此 Map 递归初始化所有的嵌套组件实例,完成页面初始化。
MVPC 的优点
- MVPC 不仅提供组件对象系统,同时也包含让它们工作的启动逻辑,而不是一些类型的简单堆砌,它是一个可以工作的完备系统,开发人员只需要专注于组件的编写。
- 每个组件原则上只操作它自身 DomScope 以内的元素,具有高内聚的特点,不会污染全局环境,以及最小的 Dom 依赖关系。
- 逻辑与表现分离,只通过系列特定的 action-anchor class 来绑定元素事件,对 Dom 结构没有强制性要求和绑定关系。
- 高度可复用,相同的组件在不同的地方使用,无须编写额外代 ,后台自动进行组装。
- 充分利用继承、多态的优势,组件设计更为优雅。
- 利用模块管理器可以实现组件的按需加载,提高前端性能。
- 前端不需要使用模板,组件都在服务器端渲染。
- 不参与逻辑处理的字段都不需要建模,所有的操作都可以理解为: 操作 -> 页面构建块更新 的过程,在此过程中,前端只需告诉后端当前发生的事件和必要参数,后端渲染好需要更新的部分,发回前端后即自动更新,完成交互过程,前端只需要少量的代码就可以完成复杂的交互效果。
MVPC 的缺点:
- 需要手动处理事件的订阅关系
- 对于不涉及数据更改的纯前端交互效果需要按传统方式编写代码。