Vue之MVVM模型

简介: Vue之MVVM模型



前言

Vue的创建者在创建Vue时没有完全遵守MVVM(一种软件架构模式),但是Vue的设计受到了他它的启发。这也是为什么经常用vm(ViewModel的缩写)这个变量名表示Vue实例。


一、简说MVVM模型

M:模型(Model),对应data内的数据

V:视图(View),模板

VM:视图模型(ViewModel),Vue实例对象

可以看下面这张图进行理解:

下面用代码实例讲解一下,方便更好理解

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <div id="app">
        <p>{{name}}</p>
        <p>{{age}}</p>
    </div>
    <script>
        new Vue({
            el: '#app',
            data: {
                name: "王五",
                age: 20
            }
        })
    </script>
</body>
</html>

上诉代码中,MVVM体现在如下图:

二、走进MVVM

看了上述内容,大家应该能大致理解一下MVVM这种设计模式了,那我们就讲的官方一点。

Model层:Model层代表了描述业务逻辑和数据的一系列类的集合。它也定义了数据的修改和操作的业务规则。

  • View层:View层代表了UI组件,如CSS、jQUery、HTML等,只负责从Presenter接收到数据,也就是把模型转化为UI。
  • ViewModel层:ViewModel层负责暴露方法命令,其他属性用来操作View的状态,组装Model作为View动作的结果,并且触发View自己的事件。
  • MVVM的核心就是数据驱动(即ViewModel),是View和Model的关系映射。ViewModel类似于中转站,负责转换Model中的数据对象,使数据更加易于管理和使用。MVVM的本质就是基于操作数据来操作视图进而操作DOM,借助于MVVM无须直接操作DOM,开发者只需完成包含说明绑定的视图模块,编写ViewModel中的业务,使得View完全实现自动化。
  • 在MVVM中,View和Model不可以直接进行通信,他们之间利用ViewModel这个中介充当观察者的角色。当用户操作View时,ViewModel会感知到变化,然后再通知Model发生相应的变化;反之亦然。ViewModel向上与View进行双向数据绑定,向下与Model通过接口请求数据交互。

总结

以上就是MVVM设计模式的讲解。

相关文章
|
3天前
|
JavaScript
vue消息订阅与发布
vue消息订阅与发布
|
3天前
|
JavaScript
vue尚品汇商城项目-day07【vue插件-50.(了解)表单校验插件】
vue尚品汇商城项目-day07【vue插件-50.(了解)表单校验插件】
12 4
|
3天前
|
JavaScript
vue尚品汇商城项目-day07【51.路由懒加载】
vue尚品汇商城项目-day07【51.路由懒加载】
13 4
|
4天前
|
JavaScript 前端开发
Vue学习笔记8:解决Vue学习笔记7中用v-for指令渲染列表遇到两个问题
Vue学习笔记8:解决Vue学习笔记7中用v-for指令渲染列表遇到两个问题
|
3天前
|
JavaScript
vue尚品汇商城项目-day07【vue插件-54.(了解)生成二维码插件】
vue尚品汇商城项目-day07【vue插件-54.(了解)生成二维码插件】
9 2
|
5天前
|
JavaScript
vue组件中的插槽
本文介绍了Vue中组件的插槽使用,包括单个插槽和多个具名插槽的定义及在父组件中的使用方法,展示了如何通过插槽将父组件的内容插入到子组件的指定位置。
|
4天前
|
JavaScript 前端开发 IDE
Vue学习笔记5:用Vue的事件监听 实现数据更新的实时视图显示
Vue学习笔记5:用Vue的事件监听 实现数据更新的实时视图显示
|
4天前
|
JavaScript 前端开发 API
Vue学习笔记4:用reactive() 实现数据更新的实时视图显示
Vue学习笔记4:用reactive() 实现数据更新的实时视图显示
|
4天前
|
JavaScript 前端开发 API
Vue学习笔记7:使用v-for指令渲染列表
Vue学习笔记7:使用v-for指令渲染列表
下一篇
无影云桌面