Vue基础知识(MVC、MVP、MVVM对比)

Vue基本知识
Vuejs是最火爆的mvvm设计开发框架。

MVC设计模式:
【MySQL】:数据库存储持久化
【Module】模型层:工具程序、【RPC分布式】业务逻辑
【controller】控制层:接受请求、数据拦截、模型层调用、操作返回
【view】显示层
用户
每一个MVC设计模式实际上都由专业人员开发编写,就当前而言,模型层:springcloud技术或者RPC技术、对于控制层使用springboot开发技术、显示层:jquery、angularJS、reactor、vue.js进行项目开发。

Mvp设计模式(最具代表的是jquery)
显示设计模式提供一种MVP设计开发框架、MVP是运行在显示层上的设计模式,核心组成:model层(数据模型层)、view层、presenter层。
Web2.0时代开启者:AJAX
【Web端】:跨域访问
【Module】数据模型
【presenter】表示层(中间层):数据模型解析、DOM元素创建
【view】数据显示
代码实现范例:
创建html文件

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>vuejs开发框架</title>
		<script type="text/javascript" src="jquery/jquery.min.js"></script>
		<script type="text/javascript" src="js/mvp.js"></script>
	</head>
	<body>
		<div id="controlDiv">
			输入数据:<input type="text" id="msg" />
			<button id="addBut">追加数据</button>
		</div>
		<div id="massageDiv">
			<select id="msgList" multiple></select>
		</div>
	</body>
</html>

创建js文件:

$(function(){
	$(addBut).on("click",function(){
		messageValue=$(msg).val();
		$(msgList).append("<option>"+messageValue+"</option>");
	});
})

运行结果:
在这里插入图片描述

以上代码解读:先所给定的mvp.js文件,起到了数据获取的功能(未使用异步访问,而是使用jquery实现动态访问),文件混乱,维护难。
改善:采用面向对象思想,采用类的形式封装,进行jqurey改善,修改mvp.js,
修改代码:

$(function(){
	var message=new Message();
	message.init();//初始化
})
function Message(){}
$.extend(Message.prototype,{
	init:function(){
		this.bindMessageEvent();
	},
	bindMessageEvent:function(){
		$(addBut).on("click",$.proxy(this.messageHandler,this));
	},
	messageHandler:function(){
		messageValue=$(msg).val();
		$(msgList).append("<option>"+messageValue+"</option>");
		$(msg).val("");
	}
})

依旧存在大量js代码,维护难,但规格化起一定规范作用。核心问题:需要由开发者进行DOM操作,提出MVVM。

**MVVM【Model-View-ViewModel】**介绍:通过viewmodel双向关联
【view】显示层
【View model】数据模型层:数据绑定-双向绑定-DOM监听
开发人员只关注数据的来源和数据的绑定
【Module】数据模型
【Web端】

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MVVM 是一种前端架构设计模式,它将界面、数据和逻辑分离并通过 ViewModel 进行交互。在 MVVM 模式中,视图(View)和模型(Model)是完全独立的,它们通过 ViewModel 进行双向绑定(Binding)。 在 Vue.js 中,MVVM 模式被称为“响应式编程”,它的核心是数据劫持和发布订阅模式。Vue.js 的数据驱动视图,通过数据改变来更新视图,这些数据是被劫持的,也就是说,当数据发生变化时,Vue.js 会自动更新视图。 Vue.js 中的 MVVM 模式包含以下三个部分: 1. 视图层(View):负责展示数据,通常是 HTML 模板。 2. 模型层(Model):负责存储数据,通常是 JavaScript 对象。 3. 视图模型层(ViewModel):负责处理视图与模型之间的交互,它是一个纯粹的 JavaScript 对象,负责实现数据绑定、数据格式化、事件监听等功能。 在 Vue.js 中,我们可以使用指令(v-directive)来实现数据绑定。指令是一种特殊的 HTML 属性,它的值通常是一个表达式,用来绑定指令所在元素的属性或事件。例如,v-bind 指令可以将一个 JavaScript 对象绑定到 DOM 元素的属性,v-on 指令可以监听 DOM 元素的事件。 除了指令之外,Vue.js 还提供了计算属性(Computed)和侦听器(Watch)等功能,用于处理数据的计算和监听数据的变化。 总之,MVVM 模式是一种前端架构设计模式,它通过 ViewModel 实现视图(View)和模型(Model)之间的双向绑定(Binding),实现了数据的自动更新和视图的响应式。在 Vue.js 中,MVVM 模式被称为“响应式编程”,它的核心是数据劫持和发布订阅模式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值