什么是MVVM?mvvm和mvc区别?

什么是MVVM

MVVM是Model-View-ViewModel的缩写。MVVM是一种设计思想。Model 层代表数据模型, 也可以在Model中定义数据修改和操作的业务逻辑;View 代表UI 组件,它负责将数据模 型转化成UI 展现出来,ViewModel 是一个同步View 和 Model的对象。 在MVVM架构下,View 和 Model 之间并没有直接的联系,而是通过ViewModel进行交互, Model 和 ViewModel 之间的交互是双向的, 因此View 数据的变化会同步到Model中, 而Model 数据的变化也会立即反应到View 上。 ViewModel 通过双向数据绑定把 View 层和 Model 层连接了起来,而View 和 Model 之间的同步工作完全是自动的,无需人为干涉,因此开发者只需关注业务逻辑, 不需要手动操作DOM, 不需要关注数据状态的同步问题,复杂的数据状态维护完全由 MVVM 来统一管理。

mvvm和mvc区别

都是一种设计思想。主要就是mvc中Controller演变成mvvm中的viewModel。 mvvm主要解决了mvc中大量的DOM 操作使页面渲染性能降低,加载速度变慢, 影响用户体验。vue数据驱动,通过数据来显示视图层而不是节点操作。

vue的优点是什么

  1. 低耦合
  2. 可重用性
  3. 独立开发

也称块间联系。指软件系统结构中各模块间相互联系紧密程度的一种度量。 模块之间联系越紧密,其耦合性就越强,模块的独立性则越差。 就是写一个组件在任何复杂的项目任何复杂的场景下都可以即拿即用这就是低耦合视图 (View)可以独立于Model变化和修改,一个ViewModel可以绑定到不同的"View"上, 当View变化的时候Model可以不变,当Model变化的时候View也可以不变

你可以把一些视图逻辑放在一个ViewModel里面,让很多view重用这段视图逻辑

开发人员可以专注于业务逻辑和数据的开发(ViewModel),设计人员可以专注于页面设计

渐进式框架没有什么限制,可以在此框架上引用其他框架,不像angular1一样 想使用框架就得使用它的一套流程限制

Vue的语法

<div id="app"></div>
  
new Vue({
	el:"#app",
	data:{存储数据的仓库,相当于声明的变量},
	methods:{存储方法的仓库,相当于函数}
})

  • 把指令插入到对应的dom元素上,实现一些不同的效果,减少DOM操作
  • v-html 插入到Dom元素中可以进行DOM元素解析,相当于js下的innerHTML
  • v-text 相当于 js的innerText 不解析DOM元素
  • v-on:click=“方法名” ,绑定方法进行操作, v-on可以使用简写的方式@,推荐简写的方式,和v-on完全等价
  • v-show=‘布尔值’ 控制元素的显示与隐藏 true 显示 false隐藏
  • v-if = ‘布尔值’ 控制元素的显示隐藏,和v-show用法完全一致,原理上有所不同
  • v-model=“绑定值” 配合表单元素使用,可以在表单中绑定data下的数据,如果其他标签中的内容和v-model绑定的内容相同,其他标签的内容会随着v-model绑定的内容联动,v-model不能使用空值
  • v-for =’(每一个数据,下标) of arr’ 进行data下数据的遍历渲染DOM元素,v-for会自动添加对等组数据个数的DOM节点
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值