MVC & MVVM
什么是MVC,什么是MVVM?
面向过程 --> 面向对象 --> MVC --> MV*
面向过程:
开发人员按照需求逻辑顺序开发代码逻辑,主要思维模式在于如何实现。先细节,后整体。
面向对象:
开发人员先思考整个需求该由谁(哪个对象)来实现,整个需求就是由很多对象来完成,然后在对象的具体逻辑中依然还是面向过程。封装+多态+继承,先抽象,后具体。
面向过程与面向对象的区别:
- 就像是电脑,面向过程是自己生产电脑,包括电路板、零件等。面向对象是自己组装电脑,硬件已生产完毕。
- 面向过程: 吃 狗(屎); 面向对象: 狗 吃(屎);
MVC:
确切的讲MVC是一种软件设计规范,早在1970年MVC的理念就已经诞生。不过长期以来MVC都是应用在重逻辑开发的软件领域和互联网产品的后台开发领域。
开发人员按照Model(模型) - View(视图) - Controller(控制器)相分离的逻辑进行需求开发,将输入(View)、处理(Controller)、输出(Model -> View)独立开,这种逻辑的好处在于,业务逻辑与用户界面分离之后,后期对于界面的改版以及对于用户交互的处理变化,仅仅需要改动View层即可,不在需要对业务逻辑层进行多大的改动。后期的维护成本会减少很多。
Model是需要渲染到页面中的数据模型,View是用户可以接触到的的界面,Controller是业务逻辑控制
MVVM:
开发人员只要考虑和处理Model(数据模型)的变化即可,不用考虑Model和View之间的数据绑定同步,更不用花精力用大量的代码获取DOM元素改变DOM元素的值来完成界面数据的变化。所有工作交给VM(View-Model)来处理。
MVVM并没有业务逻辑的控制器,它通过数据双向绑定,实时更新View和Model层,当数据模型发生变化的时候,用户界面(DOM)的内容会即时更新。反之如果用户操作导致某些DOM内容变化(如input),ViewModel也会即时的将Model数据模型更新。
实际上还有一种模式叫做MVP,P是Presenter,它与MVVM类似,但不是双向绑定。
为什么MVC?
随着互联网产品前端业务逻辑的日趋复杂,JavaScript已经从最初的仅仅实现页面动态效果,随着AJAX的诞生以及Google对于此技术的重视和推广,现在的JavaScript演变成业务逻辑越来越复杂和繁重的角色,JavaScript也完美的向世人诠释了什么才是真正的屌丝逆袭。随着网站界面的复杂化,以及越来越多的互联网产品都开始重视用户的交互体验,前端的业务逻辑和数据处理能力被更加重视,也正是随着DOM操作逻辑与业务逻辑的混杂,导致项目代码随着时间的推移越来越多,越来越混杂,越来越难以维护。最早出现的MVC理念的JS框架便是几年前进入前端领域的Backbone.js。MVC设计理念终于被应用到的前端开发的领域。也正是因为前端MVC理念的普及,更多的人认识到了前端开发工程师的价值已经不只是过去那种只做表面功夫的"伪程序员"。前端开发工程师的春天才刚刚开始。
复杂的Web App
将开发重心从DOM操作,转移到数据操作,将DOM操作与程序逻辑解耦。
期望提升开发效率、单位时间产出、后期代码扩展性,降低维护成本
MVC另一种角度来说算是一个公司技术团队的开发规范,只有规范的逻辑代码,才能获得敏捷开发的便捷和高效,也可以得到相较为规范的开发模式更好的代码扩展性和可维护性。
为什么MVVM?
数据双向绑定,开发人员不用再把精力放在DOM的修改和更新,只要通过模板引擎将数据模型和用户界面绑定,框架会实时同步双方数据的变化。减轻了开发人员的负担,也减少了DOM操作逻辑导致业务逻辑混乱的可能性。
为什么使用AngularJS
最早开始普及的前端MVC框架是Backbone,之后借鉴这种开发模式的框架如雨后春笋般进入开发者的视野。互联网巨头们也开始推出自己的MV*框架:
微软 - Knockout.js - MVVM
Google - Angular.js - MVC & MVVM
苹果 - Ember.js - MVC & MVVM
Facebook - React.js - MVVM
全栈工程师 -> MEAN解决方案
AngularJS既是MVC框架又是MVVM框架
之前有说到MVC模式就是一种开发规范,AngularJS这个MVC框架带给我们的好处就是,他经过了Google很多项目的考验,我们使用AngularJS也可以算是使用Google成熟的开发规范来进行项目开发。AngularJS这个MVC框架实际上汇集了太多太多Google的优秀理念和编程规范,这对于很多希望能统一开发规范的前端Team来说是很宝贵的。
AngularJS既是MVC框架又是MVVM框架
之前有说到MVC模式就是一种开发规范,AngularJS这个MVC框架带给我们的好处就是,他经过了Google很多项目的考验,我们使用AngularJS也可以算是使用Google成熟的开发规范来进行项目开发。AngularJS这个MVC框架实际上汇集了太多太多Google的优秀理念和编程规范,这对于很多希望能统一开发规范的前端Team来说是很宝贵的。
MVC & MVVM的更多相关文章
- MVP MVC MVVM 傻傻分不清
最近MVC (Model-View-Controller) 和MVVM (Model-View-ViewModel) 在微软圈成为显学,ASP.NET MVC 和WPF 的Prism (MVVM Fr ...
- mvc/mvvm小小的总结
mvc/mvvm 阮大神博客 mvc 分为三层,其实M层是数据模型层,它是真正的后端数据在前端js中的一个映射模型,他们的关系是:数据模型层和视图层有映射关系,model改变,view展示也会更改,当 ...
- 我的架构设计~用层关系图说说mvc,mvvm,soa,ddd
下面是按着我所接触的架构模式,开始一个一个的说一下 第一 标准架构 三层结构
- iOS MVC, MVVM
在iOS app里,如果用传统的MVC模式,Model层就是数据,View层就是Storyboard,nib文件或者构建UI的代码,Controller层就是ViewController,负责协调Mo ...
- JavaScript富应用MVC MVVM框架
对框架的挑选 Ember.js.Backbone.js.Knockout.js.Spine.js.Batman.js , Angular.js 1. 轻量级的应用选择哪一个会比较好?2. 那一个比较简 ...
- MVP, MVC, MVVM, 傻傻分不清楚~
1 简介 英文原文:MVC vs. MVP vs. MVVM 三者的目的都是分离关注,使得UI更容易变换(从Winform变为Webform),使得UI更容易进行单元测试. 2 MVC/MVP 2.1 ...
- MVC,MVVM,MVP的区别/ Vue中忽略的知识点!
按照顺序学习: https://scotch.io/courses/build-an-online-shop-with-vue/hello-world Vue Authentication And R ...
- 通俗理解 MVC , MVVM
MVC 也就是Model-View-Controller 的缩写,就是 模型-视图-控制器 : Model :管理数据 View :视图展示 Controller :响应用户操作,并将 Model 更 ...
- 学习笔记之ASP.NET MVC & MVVM & The Repository Pattern
ASP.NET MVC | The ASP.NET Site https://www.asp.net/mvc ASP.NET MVC gives you a powerful, patterns-ba ...
随机推荐
- 用static关键字修饰类
Java里面static一般用来修饰成员变量或函数.但有一种特殊用法是用static修饰内部类,普通类是不允许声明为静态的,只有内部类才可以.被static修饰的内部类可以直接作为一个普通类来使用,而 ...
- C++:用成员初始化列表对数据成员初始化
1.在声明类时,对数据成员的初始化工作一般在构造函数中用赋值语句进行. 例如: class Complex{ private: double real; double imag; public: Co ...
- svn 版本升级的问题
原创文章,转载请注明 svn本地版本由1.6升级到1.7后,再使用时遇到一些问题,这里记录一下以备忘. 升级后,使用任何命令 不能用了,提示的意思大致是本地的workcopy版本太低了(之前用1.6版 ...
- Codeforces Beta Round #2B(dp+数学)
贡献了一列WA.. 数学很神奇啊 这个题的关键是怎么才能算尾0的个数 只能相乘 可以想一下所有一位数相乘 除0之外,只有2和5相乘才能得到0 当然那些本身带0的多位数 里面肯定含有多少尾0 就含有多少 ...
- SGU 275 To xor or not to xor (高斯消元)
题目链接 题意:有n个数,范围是[0, 10^18],n最大为100,找出若干个数使它们异或的值最大并输出这个最大值. 分析: 一道高斯消元的好题/ 我们把每个数用二进制表示,要使得最后的异或值最大, ...
- ViewPager介绍和使用说明
1 ViewPager实现的功能 和实际运行的效果图示意 ViewPager类提供了多界面切换的新效果.新效果有如下特征: [1] 当前显示一组界面中的其中一个界面. [2] 当用户通过左右滑动界 ...
- Qt之启动外部程序
简述 QProcess可以用来启动外部程序,并与它们交互. 要启动一个进程,通过调用start()来进行,参数包含程序的名称和命令行参数,参数作为一个QStringList的单个字符串. 另外,也可以 ...
- BZOJ3806: Neerc2011 Dictionary Size
题解: 这题搞得我真是酸(dan)爽(teng) 原来一直不会,一定会用到什么神奇的东西.因为重复的不知道如何计算. 今天中午睡起来忽然想到好像可以在正trie上故意走无出边,因为这样就保证了这次统计 ...
- hdu 4691 Front compression
暴力水过,剪一下枝= =果断是数据水了 #include<cstdio> #include<cstring> #include<algorithm> #define ...
- django - request.raw_post_data 与 request.body
request.raw_post_data 重命名成了 request.body - 在1.3版本之后. 这是当时 起票 的讨论内容:https://code.djangoproject.com/ti ...