ASP.NET MVC与ASP.NET WebForm

     ASP.NET
MVC是微软公司之同一舒缓WEB开发框架,整合了“模型-视图-控制器”架构的短平快和洁,是飞速开发极现代之思想以及技能。它是风ASP.NET
WebForm的一个完美之替代品。

1、当今的Web开发

    
1)REST(Representational State
Transfer)已经改成应用程序在HTTP上互操作的第一系架构,完全使SOAP失色。REST是基于代表真实世界实体的资源(URI)和代表以这些资源达成可用的正统操作方法(HTTP方法)来叙述一个应用程序。透过HTTP方法及资源地址的重组就可以本着资源执行相应的操作,这种结合就是REST,执行这种操作的乞求也叫REST化的恳求。(对于REST的知道个人还是免透,后面会对这个概念进行补充)

时下之Web应用程序不只是供HTML服务,通常为急需以XML或JSON数据提供被用户,而WebForm很麻烦支撑。

    
2)整个软件行业向着敏捷和测试驱动开发方向的前进,如单元测试工具(NUnit、xUnit)、模仿框架(Moq、Rhino、Mocks)、控制反转容器(Ninject、AutoFac)、持续集成服务器(CruiseControl、TeamCity)、对象关系映射器(NHibernate、Subsonic、EF、Dapper、Petapoco)、UI自动化工具的供。(测试驱动开发TDD思想:首先描述想如果得到的行为范例,称为测试规范;然后进行软件设计,这样经过执行依附于即等同落实的平仿测试,来证明应用程序的安宁以及科学

    
3)顺应Web标准以及REST化的来头。

2、ASP.NET WebForm的历史和问题

    
ASP.NET WebForm之技术堆栈,如下图所示:

    
房地产项目 1

    
此图的意义是WebForm建立于ASP.NET之上,而ASP.NET又另起炉灶以.NET平台之上,MVC框架所于底打算是代表WebForm。

    
WebForm的宏图思想是,让Web开发以感觉上及Windows
Form开发同。开发者不再要盖平等系列独立的HTTP请求和响应进行工作,可以看她是同一栽状态化的UI,人们可淡忘WEB及其无状态本质,转而用一种“拖–放”式设计器来创造UI,并考虑所有事务还发生在服务器上。

    
趁年华的延,WebForm在实际上项目蒙出现了片瑕疵:

    
1)视图状态重负:维护状态的实际机制,也尽管是ViewState(视图状态)导致在客户端和服务器之间传输大块数据(达到几百KB),而且来回于每次要中,导致响应时间特别缓慢,增加了服务器的拉动富需求;

    
2)页面生命周期:连接客户端与劳务器端事件处理器代码的机制很复杂,对于应用程序运行期间生麻烦展开保障;

    
3)关注分离的失实观点:本身将代码从HTML提取出,放到后台代码类中开展处理是格外均等栽死好的艺术,但是有开发者在后台代码中将展现代码和下工作逻辑混合在一起,导致最终代码乱并难以保障;

    
4)HTML的受限控制:服务器控件将自己渲染成HTML,但连无是所希望观看底HTML,在ASP.NET
4之前,并无克十分好之采用CSS。同时会生成不可预知或复杂的ID,这样JavaScript就格外不便展开访问。

    
5)有欠缺的悬空:WebForm试图尽量隐去HTML和HTTP(这是通过WebForm的泛层实现的)。当你实现协调之办法时,需要放弃这种肤浅,迫使采取回发事件机制的逆向工程。所以这种肤浅对于开发者而言就结成一个庞然大物的阻碍与挑战;

    
6)低而测试性:WebForm的这种紧耦合体系布局并无符合吃单元测试,对于集成测试为死富有挑战性;

3、ASP.NET
MVC的特点

    
1)ASP.NET
MVC框架实现了MVC模式(MVC模式于1978年虽已经提取出来了),由于ASP.NET
MVC极大的改良了关爱分离,所以专门适用于Web应用程序。因为跟MVC应用程序的相遵循着用户动作和视图更给之自然周期,在斯周期被,假设视图是无论状态的。这跟支持Web应用程序的HTTP请求和应措施大吻合。

    
2)可扩展性,MVC框架被构建成一样多重独立的组件,如路由于系统、视图引擎、控制器工厂,你可老容易地用一个投机之不等实现来替换这些零部件,通常发生三栽选择:

         
a、使用组件现行的默认实现,此种好满足大多数应用程序;

         
b、派生默认实现的一个子类,以调动其行事;

         
c、用接口或者抽象基类的一个初的落实来完全替换该器件;

    
3)HTML和HTTP上之严密控制,ASP.NET
MVC会生整洁和业内相当的记,其厝的HTML辅助器方法,可以产生及正式相当的出口。ASP.NET
MVC生成的页面不包含其他ViewState数据,这种针对带宽的省,可以大幅度的精益求精用户的体会,并且可以针对浏览器与服务器之间传递的求加以控制。

    
4)可测试性,ASP.NET
MVC应用程序不仅可以进行单元测试,还得同UI自动化测试工具良好合作。

    
5)强大的路由系统,采用REST风格的路由方案,有如下好处:

    
     a、搜索引擎对URL中找到的关键词有显著的权重,对相同的最主要词的摸,极有或会见转接一个较为简单的URL地址;

         
b、许多Web用户现在针对URL有足够的会心,并且愿意当浏览器的地方栏目中输入URL地址;

         
c、当了解URL地址房地产项目之布局后,人们才见面重产生或链接它,并朝其他人共享;

         
d、此种植URL结构并无见面以应用程序的技术细节、文件夹、文件名称等组织暴露被互联网。对于底层实现可随心所欲修改,而未会见坏链接;

    
6)建立在ASP.NET平台之上,一方面ASP.NET
MVC是基于.NET平台的,因此好灵活的用任何.NET语言来编排代码,可以采用大规模的.NET类库和大量之老三方.NET类库系统;另一方面,已经形成的ASP.NET平台特色,如认证、成员、角色、配置文件、国际化等得以减少支出与护卫Web应用程序所用之代码量。

    
7)ASP.NET MVC是针对.NET
4.X比方建立的,因此她的API可以充分利用当前语言及运作时的换代,如await关键字、扩展方法、lambda表达式、匿名、动态类型、LINQ。

    
8)ASP.NET MVC是开源的。

4、ASP.NET
MVC与ASP.NET WebForm的比较

    
首先得征的是,虽然ASP.NET MVC相对于ASP.NET
WebForm来说有一些优势,但这并无意味前者要代表后者,也非表示后者要流失。

  • WebForm的观念是,UI应该是状态化的,其结果是,在HTTP和HTML之上添加一个抽象层,用视图状态(ViewState)和回发(Postback)来创造状态化的意义。这是千篇一律种“拖放”式Windows
    Form风格的开发。

  • MVC采纳了HTTP真正无状态的面目。MVC框架要求用户知道Web应用程序实际的劳作措施,在知晓的前提下,进行维护及扩张,提供相同种植功能强大、简单的、整洁的、现代之法子来修Web应用程序,摆脱复杂的限定。

  • 用说,开发小型的,企业里型应用程序,可以考虑采取WebForm的法来落实,但还多之时段,开发互联网应用程序或者大型的应用程序时,MVC无论从效率、兼容性、维护性都是同一种植更好的选择。

参考资料:《精通ASP.NET MVC X》

相关文章