1.mvvm模型浅谈
- mvvm模型指的是:model(模型) view(视图) viewmodel(视图模型层)
MVVM 的核心是 ViewModel 层,负责转 换 Model 中的数据对象来让数据变得更容易管理和使用,其作用如下: 该层向上与视图层进行双向数据绑定 向下与 Model 层通过接口请求进行数据交互 。
MVVM 已经相当成熟了,当下流行的 MVVM 框架有 Vue.js , AngularJS 等。
- mvvm和mvc十分相似,它们都分离了model 和 view ,他们都具有以下优点:
- 低耦合: 视图(View)可以独立于 Model 变化和修改,一个 ViewModel 可以绑定到不同的 View 上,当 View 变化的时候 Model 可以不变,当 Model 变化的时候 View 也可以不变。
- 可复用: 你可以把一些视图逻辑放在一个 ViewModel 里面,让很多 View 重用这段视图逻辑。
- 独立开发: 开发人员可以专注于业务逻辑和数据的开发(ViewModel),设计人员可以专注于页 面设计。
- 可测试: 界面素来是比较难于测试的,而现在测试可以针对 ViewModel 来写。
1.1.mvvm的模型
!](https://www.icode9.com/i/ll/?i=20210403194751418.png?,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2FiYWlkYXll,size_16,color_FFFFFF,t_70)
-
View: View 是视图层,也就是用户界面。前端主要由 HTML 和 CSS 来构建,为了更方便地展现 ViewModel 或者 Model层的数据,已经产生了各种各样的前后端模板语言,比如 FreeMarker、 Thymeleaf 等等,各大 MVVM 框架如 Vue.js,AngularJS,EJS 等也都有自己用来构建用户界面的内置 模板语言。
-
Model: Model 是指数据模型,泛指后端进行的各种业务逻辑处理和数据操控,主要围绕数据库系统展开。这里 的难点主要在于需要和前端约定统一的 接口规则 ViewModel:
-
ViewModel 是由前端开发人员组织生成和维护的视图数据层。在这一层,前端开发者对从后端获取的 Model 数据进行转换处理,做二次封装,以生成符合 View 层使用预期的视图数据模型。
View 层展现的不是 Model 层的数据,而是 ViewModel 的数据,由 ViewModel 负责与 Model 层交互,这就完全解耦了 View 层和 Model 层,这个解耦是至关重要的,它是前后端分离方 案实施的重要一环。
1.2.关于双向绑定和虚拟dom的个人理解
- 双向绑定:指的是view层和viewmodel层的双向绑定,因为有了双向绑定,使得viewmodel层可以直接操作view层,view层的操作也会第一时间反馈到viewmodel层,使得用户的交互可以在不刷新页面的前提下,改变model层,使得网页加载更快,提高加载效率。
- 虚拟dom:虚拟dom指的是在页面中的数据是动态的,是viewmodel控制的动态数据,可以通过viewmodel在不刷新页面的前提下改变。也就是说页面展示的dom都是可以随时改变的,没有固定的实际值,所以被称为虚拟dom。