最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Vue学习之与MVVM的对应关系

    正文概述 掘金(Schaffer)   2021-05-28   513

    Vue是受MVVM启发的,那么有哪些相同之处呢?以及对应关系?

    MVVM(Model-view-viewmodel)

    MVVM还有一种模式model-view-binder,主要用来简化用户界面的事件驱动程序设计。

    MVVM可以分成四部分

    • Model:模型
    • View:视图
    • ViewModel:视图模型
    • Binder:绑定器

    主要形式还是Model-ViewModel-View

    Vue学习之与MVVM的对应关系

    Vue和这四部分的关系

    对应关系:

    • 视图:对应真实的html和css
    • 视图模型:对应Vue的模板语法
    • 绑定器:对应v-bind v-model @click :prop等绑定数据语法
    • 模型:Vue的实例中的那些属性 datamethods $computed 等等

    在一个.vue文件中,我们会看到3部分<template /> <script /> <style />

    • <template /> 负责视图模型和绑定器
    • <style /> 负责视图的CSS
    • <script /> 中定义的Vue实例负责模型的数据管理和绑定器的逻辑

    如何用Vue解释Model-ViewModel-View呢?

    ViewModel-View阶段 视图模型转化为视图,也即Vue中的模板语法转化为实际的HTML和CSS,这个部分主要由Vue自动实现,我们开发者主要处理的是Model-ViewModel阶段。 Model-ViewModel阶段 这个阶段就是我们实例化Vue对象,添加data,methods等操作,以及将数据绑定到模板上。

    <template>
      <div class='test' @click='add'>{{count}}</div>
    </template>
    
    // <script>
    export default {
      data () {
        return {
          count: 0
        }
      },
      methods: {
        add (e) {
          this.count += 1
        }
      }
    }
    

    Model:定义data函数管理数据count,以及定义add函数控制count数据的变更
    ViewModel:是抽象语法,主要是Vue的模板语法,绑定数据,之后Vue会将其转化为真实的HTML
    由于,ViewModel和Model主要是绑定关系,也即是数据和视图是绑定的,你什么样的数据就决定了什么样的视图,所以我们一般也把Vue称为数据驱动框架。
    所以很多时候,只要知道数据和ViewModel的关系,也就知道UI的样子了,这个时候,我们只需操作数据的结构,也就操作了视图。

    <template>
      <ul class='list'>
        <li class='item' v-for='(v, index) in arr' :key='index'>{{v}}</li>
      </ul>
    </template/>
    
    export default {
      data () {
        return {
          arr: [1, 2, 3, 4, 5]
        }
      },
      created () {
        // 改变数据arr的数据结构,添加新的数值
        this.arr.push(6)
      }
    }
    

    Model和ViewModel的关系:

    arr和<li>标签绑定,有多少个arr元素就有多少个<li>
    后面arr添加了一个元素6,这时候arr的长度是6,那应该有6个<li>,这就是数据和视图的绑定,由数据的结构我们就可以推出视图的样子。
    所以我们要多从操作数据的角度思考问题,当然前提是你已经确定了Model和ViewModel的绑定关系是怎样的。这个时候我们只需操作Model就可以了。
    上面的例子采用的数据结构是数组,当然还有很多数据结构。Model和ViewModel绑定后,基本上Model的数据结构就决定了。那么这时,我们只需根据这个Model的数据结构增删修改。
    还有一点就是vue中有多种绑定方式,v-if v-for 等等,一个ViewModel只有一个Model的数据结构,但是相同的View可以有多种ViewModel
    比如这个View<div>hello</div>,有多种ViewModel都可以生成这个,有多种ViewModel也即有多种Model(数据结构)

    <template>
      <div>{{data}}</div>
      <div>{{obj.data}}</div>
      <div>{{arr[0]}}</div>
    </template>
    
    export default {
      data () {
        return {
          data: 'hello',
          obj: {
            data: 'hello'
          },
          arr: ['hello']
        }
      }
    }
    

    上面有3种ViewModel和3种Model 但生成的View都是一样的<div>hello</div>


    起源地下载网 » Vue学习之与MVVM的对应关系

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元