什么是MVVM

引言

2008年,V8 引擎随 Chrome 浏览器横空出世,JavaScript 这门通用的 Web 脚本语言的执行效率获得质的提高。 V8 引擎的出现,注定是 JavaScript 发展史上一个光辉的里程碑。它的出现,让当时研究高性能服务器开发、长时间束手无策的 Ryan Dahl 有了新的、合适的选择,不久,在2009年的柏林的 JSConf 大会上,基于 JavaScript 的服务端项目 Node.js 正式对外发布。Node.js 的发布,不只为开发者带来了一个高性能的服务器,还很大程度上推进了前端的工程化,带来了前端的大繁荣。与此同时,由于 JavaScript 执行效率的巨大提高,愈来愈多的业务逻辑开始在浏览器端实现,前端逻辑愈来愈重,前端架构随之提上日程。因而,咱们谈论的主角,MVVM 模式,走进了 Web 前端的架构设计中。前端

概念

MVVM 模式,顾名思义即 Model-View-ViewModel 模式。它萌芽于2005年微软推出的基于 Windows 的用户界面框架 WPF ,前端最先的 MVVM 框架 knockout 在2010年发布。git

一句话总结 Web 前端 MVVM:操做数据,就是操做视图,就是操做 DOM(因此无须操做 DOM )。github

无须操做 DOM !借助 MVVM 框架,开发者只需完成包含 声明绑定 的视图模板,编写 ViewModel 中业务数据变动逻辑,View 层则彻底实现了自动化。这将极大的下降前端应用的操做复杂度、极大提高应用的开发效率。MVVM 最标志性的特性就是 数据绑定 ,MVVM 的核心理念就是经过 声明式的数据绑定 来实现 View 层和其余层的分离。彻底解耦 View 层这种理念,也使得 Web 前端的单元测试用例编写变得更容易。浏览器

MVVM,说到底仍是一种分层架构。它的分层以下:服务器

  • Model: 域模型,用于持久化架构

  • View: 做为视图模板存在框架

  • ViewModel: 做为视图的模型,为视图服务mvvm

Model 层

Model 层,对应数据层的域模型,它主要作域模型的同步。经过 Ajax/fetch 等 API 完成客户端和服务端业务 Model 的同步。在层间关系里,它主要用于抽象出 ViewModel 中视图的 Model。函数

View 层

View 层,做为视图模板存在,在 MVVM 里,整个 View 是一个动态模板。除了定义结构、布局外,它展现的是 ViewModel 层的数据和状态。View 层不负责处理状态,View 层作的是 数据绑定的声明指令的声明事件绑定的声明组件化

ViewModel 层

ViewModel 层把 View 须要的层数据暴露,并对 View 层的 数据绑定声明指令声明事件绑定声明 负责,也就是处理 View 层的具体业务逻辑。ViewModel 底层会作好绑定属性的监听。当 ViewModel 中数据变化,View 层会获得更新;而当 View 中声明了数据的双向绑定(一般是表单元素),框架也会监听 View 层(表单)值的变化。一旦值变化,View 层绑定的 ViewModel 中的数据也会获得自动更新。

前端 MVVM 图示

mvvm.png

如图所示,在前端 MVVM 框架中,每每没有清晰、独立的 Model 层。在实际业务开发中,咱们一般按 Web Component 规范来组件化的开发应用,Model 层的域模型每每分散在在一个或几个 Component 的 ViewModel 层,而 ViewModel 层也会引入一些 View 层相关的中间状态,目的就是为了更好的为 View 层服务。

开发者在 View 层的视图模板中声明 数据绑定事件绑定 后,在 ViewModel 中进行业务逻辑的 数据 处理。事件触发后,ViewModel 中 数据 变动, View 层自动更新。由于 MVVM 框架的引入,开发者只需关注业务逻辑、完成数据抽象、聚焦数据,MVVM 的视图引擎会帮你搞定 View。由于数据驱动,一切变得更加简单。

MVVM框架的工做

不可置否,MVVM 框架极大的提高了应用的开发效率。It's amazing!But,MVVM 框架到底作了什么?

  • 视图引擎

视图引擎:我是视图引擎,我为 View 层做为视图模板提供强力支持,开发者,大家不须要操做 DOM ,丢给我来作!

  • 数据存取器

数据存取器:我是数据存取器,我能够经过 Object.defineProperty() API 轻松定义,或经过自行封装存取函数的方式曲线完成。个人内部每每封装了 发布/订阅模式,以此来完成对数据的监听、数据变动时通知更新。我是 数据绑定 实现的基础。

  • 组件机制

组件机制:我是组件机制。有追求的开发者每每但愿按照面向将来的组件标准 - Web Components 的方式开发,我是为了知足你的追求而生。MVVM 框架提供组件的定义、继承、生命周期、组件间通讯机制,为开发者面向将来开发点亮明灯。

  • more...

结语

有了前端 MVVM 框架,应用开发如此简单!

前端 MVVM 已经是趋势,是大型 Web 应用开发效率提高的利器。由百度 EFE 出品的 MVVM 框架 - san,在保持功能强大、特性支持完整的前提下,还兼顾到IE8的市场份额,对老版本浏览器提供了良好的兼容性,更难能难得的是 GZip 后体积仅 11k, 现已为百度内多个产品提供了强劲驱动,可谓百度 EFE 又一精工之做!开源的 san 欢迎广大开发者体验、使用,更欢迎广大开发者加入到 san 生态 的建设中来,让 san 变得更好!

相关文章
相关标签/搜索