首页 > 其他分享 >【Vue】大悟!MVVM模型

【Vue】大悟!MVVM模型

时间:2023-09-19 14:02:39浏览次数:39  
标签:Vue MVVM 大悟 ViewModel VM 视图 Model View

hello,我是小索奇,精心制作的Vue教程持续更新哈,想要学习&巩固&避坑就一起学习叭~

MVVM 模型

Vue虽然没有完全遵循MVVM模型,但Vue的设计也收到了它的启发在文档中也会使用VM(ViewModel的缩写)这个变量名表示Vue实例(Vue作者参考了MVVM模型,并非其创建的)

【Vue】大悟!MVVM模型_MVVM

img

模型说明

  • M:模型 Model-对应data中的数据
  • V:视图 View-对应模板代码
  • VM:视图模型 ViewModel-对应Vue实例对象
  • Data Bingdings:数据绑定 把数据放在View的指定位置
  • DOM Listeners:DOM 监听器 监听视图上的变化并映射到数据里
  • data中所有的属性,最后都会出现在VM身上
  • VM身上所有的属性 及Vue原型身上所有的属性,在 Vue模板中都可以直接使用

Vue 实例中的 data 对象就代表了这个 ViewModel(VM) 中的 数据模型,用于存放应用程序的业务数据

Vue 中的 template 就代表视图层(View),用于定义应用程序的界面显示效果,

  • 可以将该层理解为html页面中的元素,比如:
<div id="app">{{ message }} 
</div>

在这里写的所有代码,都会去VM身上去找,比如@click = '可以引用VM的内容&简单表达式'但是如果写@click = 'alert(1)'就不对了,它属于window的,VM身上找不到就未定义错误

拓展

这里简单拓展一下:Java中的MVC(模型Model-视图View-控制器Controller-一种架构模式)

MVC:M代表Model数据层 , V代表View视图层 , C代表Controller控制层(中介), 用户发送请求,Control View 传送指令到 Controller,Controller 完成业务逻辑后,使 Model 改变状态Model 将新的数据发送到 View,用户得到反馈(实际上更复杂,如需要深入理解,建议多多查阅相关资料)

【Vue】大悟!MVVM模型_MVVM_02

image-20230814104731446

拓展Springboot+Vue架构

【Vue】大悟!MVVM模型_Vue_03

image-20230915014353293

代码示例

// View
    <div id="root">
        <h1>{{name}}</h1>
        <!-- 只要是VM上面的(包括原型)都可以直接写,f12可以查看到我们写的name、add、官方自带的属性等 -->
        <h1>{{$options}}</h1>
        <h1>{{$emit}}</h1>
    </div>
    <script type="text/JS">
        Vue.config.productionTip = false
        // new Vue 这整个就是最重要的ViewModel
        new Vue({
            el: '#root',
            // Model ,数据经过ViewModel就去了View更新
            data: {
                name: "小索奇",
                add: "shanghai"
            }
        })
    </script>

如果对您有用的话请点个免费的爱心叭~

标签:Vue,MVVM,大悟,ViewModel,VM,视图,Model,View
From: https://blog.51cto.com/u_16088329/7524835

相关文章

  • Vue-与后端交互的三种方式、箭头函数、显示电影小案例
    与后端交互的三种方式前后端需要打通-----》从前端发送ajax-----》ajax的核心:使用js发送http请求,接收返回-原生js,可以开启ajax,但是原生js开启,比较麻烦,需要做浏览器兼容,有坑(基本不写)-jq,写了个兼容所有浏览器的$.ajax(),不仅仅有ajax,还封装了很多dom操作-如......
  • 12-Vue核心-绑定样式
    class与style绑定1)在应用界面中,某个(些)元素的样式是变化的2)class/style绑定就是专门用来实现动态样式效果的技术class绑定样式写法:v-bind:class ="xxx"或:class="xxx",xxx可以是字符串、对象、数组1)字符串写法适用于:只绑定一个样式,类名不确定,需要动态获取2)数......
  • Vue收集表单数据
    收集表单数据v-model的使用data:{ account:'',//用户输入 password:'', age:'', sex:'',//需要配置 hobby:[], agree:''}若,则v-model收集的是value值,用户输入的就是value值。若,则v-model收集的是value值,需要配置value值。性别:男<inputtype=&qu......
  • 如何在vuejs项目中使用md5加密密码的实现
    1、NPM安装:npminstall--savejs-md52、全局用法2.1、全局引用importmd5from'js-md5';Vue.prototype.$md5=md5;2.2、全局使用将您需要加密的信息放进去:this.$md5('Thisisencryptedcontent')//6f43dd5db792acb25d6fe32f3dddac703.局部用法在页面中单独使用......
  • vue前端图片上传并显示
    今天完成了vue前端对数据库中图片的显示,并可以对上传的图片添加到数据库中添加修改  数据库信息 ......
  • vue的目录结构和简单的开发流程(只有最简单的一部分)
    通过将Vue挂载到app上,然后再放到div上面 ......
  • Vue-js循环方式、v-model的使用、事件处理、表单控制、购物车案例
    js循环方式在es6语法中:(以后尽量少用var有很多坑)-let:定义变量-const:定义常量1.方式一:for循环,基于索引的循环<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>Title</title><scriptsrc=".......
  • Vue之js循环方式、v-model 的使用、事件处理、表单控制、购物车案例、v-model修饰符
    js循环方式<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>js循环方式</title><scriptsrc="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.js"></sc......
  • vue-dayu03
    js循环方式一:基于索引的循环<script>leti=0for(;i<10;){console.log(i)i++}letgood_list=[1,2,3]for(letj=0;j<good_list.length;j++){console.log(good_list[j])}</script>方式二:in循环  基于迭代的循环,依赖于索引取......
  • vue2项目创建
    vue2项目基本安装vuecreare项目名cd项目名code.按照其它模块element-uinpmielement-ui-S在main.js中写入以下内容:importVuefrom'vue'importAppfrom'./App.vue'importElementUIfrom'element-ui';Vue.config.productionTip=falseim......