一、何谓MVC
1.MVC是开发时所使用的一种架构(框架)。
2.目的在于简化软件开发的复杂度,以一种概念简单却又权责分明的架构,贯穿整个软件开发流程,通过“商业逻辑层”与“数据表现层”的切割,让这两部分的信息切割开来,用以撰写出更模块话、可维护性高的程序代码。
3.MVC让软件开发的过程大致切割成三个主要单元,分别为:Model(模型)、View(视图)、Controller(控制器)。
(1)Model:负责定义信息格式与信息访问的界面,包括商业逻辑与信息验证。
(2)View:负责用户界面相关表现,包括输入与输出。例如显示HTML5网页、HTML表单域、显示XML文件等等。不要将商业逻辑与程序控制写在视图里。
(3)Controller:负责控制系统运行的流程、跟浏览器如何交互、决定网页操作的流程、响应客户端的各种要求、错误处理,等等。
二、为什么要ASP.NET MVC
1.关注点分离(Separation of Concerns, SoC)
当你在进行软件开发时,可以只关注在当前的对象上,一次仅关注于一个较容易理解与解决的部分,不会受到相同系统中其他对象的干扰,包括所有对对象的修正也不会影响其他对象的运作,进而专注于完成工作,如此一来,不但容易提升软件质量,还可加快程序代码理解的速度。MVC设计样式拥有非常清楚的关注点分离架构,使各种不同大小的网站更容易维护,也能因应不同的需求来变更,以加速项目开发并提高更好的客户满意度。
2.关注点分离的特性与优点
(1)简化复杂度
若能将复杂的问题,拆解成数个容易解决的单元,并且让你一次仅关注于一个较容易理解的部分,如此,自然能够简化软件开发的复杂度。而简化复杂度意味着程序代码数量变少,相对的也降低了程序错误(Bugs)出现的机率。
(2)可维护性大幅提升
在ASP.NET MVC里,不仅区分Model、View、Controller三种关注点,若项目越来越大,复杂度越来越高的话,你还可以再切割成更多层次,只要关注点能够清楚地分离,降低对象之间的耦合关系,相对的你也就越容易掌握项目的各个环节,这样便能让项目更易于维护。
(3)更容易测试
由于单元测试是软件测试的最小单位,以往开发人员在ASP.NET Web Form架构下并不容易撰写单元测试程序,不过采用ASP.NET MVC框架进行开发时,却非常适合撰写单元测试程序,若项目能不断强化关注点分离的特性,将能够更有效率地实施单元测试。也因为这点,选择ASP.NET MVC架构的团队,更适合采用测试导向开发方法(TDD)来进行项目建置,提升程序代码质量。
3.以习惯替换配置
以习惯替换配置(Convention over Configuration)是一种软件设计模式,主要目的在于减少开发人员在架构时所决策的时间以降低软件设计过于弹性,而导致太复杂的情况,通过约定俗成的“开发习惯”,让同一群开发人员得以共享同一套设计架构,减少思考时间,降低沟通成本,且不失软件开发的弹性。
ASP.NET MVC就是一个合理使用以习惯替换配置的开发框架,它通过MVC设计模式常见的规则,切割成Model、View、Controller三个部分,而且明确定义开发人员必须按照特定的“习惯”来开发程序。
4.MVC的优缺点
优点:
(1)清楚的关注点分离强迫你写出比Web Forms更容易维护的程序。(2)开放特性(完全开放源代码)(3)社群支持(当前国外社群非常活跃)。(4)可轻易地控制HTTP的输出属性
(5)优秀的开发效率。(6)易于测试的架构。(7)易于分工的架构。
缺点:
(1)相较于Web Forms来说,ASP.Net MVC较缺乏工具支持。(2)开发人员必须面对HTML、CSS与JavaScript在View页面上的配置,不像使用Web Forms开发网站时,即使不懂HTML、CSS、JavaScript也能开发网站。(3)缺乏成熟的组件化技术支持(Server Control、HTML Helper)。
5.开发ASP.NET MC项目时的建议
(1)不要重复自己
(2)没有完美的架构,只有适合的架构
(3)发挥“想象力”才能让开发更顺利
(4)适合的设计模式有助于提升架构质量
(5)切割你的脑袋,而且至少切成三份
(6)写程序、想架构,一定要有“感受”
(7)创建有责任感的物件
(8)对象合作要有所规范
(9)相信永远有更好的解决方法
(10)没有人可以将软件一次写对
(11)不要为了改变而改变,改变是为了适应未来
三、练习与分析
1.设计一个留言本管理系统,完成新建、显示留言功能。
- 成绩排行榜
- 第1名:陈力豪,38分钟
2.分析
(1)注意连接数据库的问题
(2)掌握CRUD的代码
(3)使用Razor语法输出属性,默认所有数据都会使用HTML编码(HtmlEncode)输出,这是出自于程序安全考虑,避免网页遭受跨网站脚本攻击(Cross-Site Scription Attach)
(4)@Html.ActionLink
(5)View里可能会编写一些程序逻辑,但仅限于编写与“显示”有关的逻辑为主,大部分的商业逻辑不应该写死在视图中,这样才能有效提升项目的维护能力。
(6)ASP.NET MVC网站的母版页面是_Layout.cshtml。
(7)所有ASP.NET Web应用程序运行的入口点在Global.asax的 Application_Start() 方法中
3.提问
如果首页只显示最近更新的5条留言,怎么改?