《精通 ASP.NET MVC 3 框架(第三版)》----第1章 设计思路 1.1 Web开发简史

简介: ASP.NET MVC是微软研发的Web开发框架,它整合了“模型—视图—控制器(MVC)”架构的高效与整洁,敏捷开发中最新的思想与技术,以及当前ASP.NET平台的精华部分。ASP.NET MVC可以完全替代传统的ASP.NET Web Form,除了一些微不足道的Web小项目,在各种Web开发项目中它都具有明显的优势。

本节书摘来自异步社区《精通 ASP.NET MVC 3 框架(第三版)》一书中的第1章,第1节,作者: 【美】Adam Freeman , Steven Standerson,译者: 林逸 , 李萍 , 更多章节内容可以访问云栖社区“异步社区”公众号查看。

第1章 设计思路

精通 ASP.NET MVC 3 框架(第三版)
ASP.NET MVC是微软研发的Web开发框架,它整合了“模型—视图—控制器(MVC)”架构的高效与整洁,敏捷开发中最新的思想与技术,以及当前ASP.NET平台的精华部分。ASP.NET MVC可以完全替代传统的ASP.NET Web Form,除了一些微不足道的Web小项目,在各种Web开发项目中它都具有明显的优势。在本章中,你将了解微软当初创建ASP.NET MVC的原因,与它的前辈和替代品之间的区别,以及ASP.NET MVC 3的新特性。

本文仅用于学习和交流目的,不代表异步社区观点。非商业转载请注明作译者、出处,并保留本文的原始链接。

1.1 Web开发简史

精通 ASP.NET MVC 3 框架(第三版)
要理解ASP.NET MVC的特色及其设计目标,有必要考察一下Web开发的历史。近年来,微软的Web开发平台演变得越加强大,如表1-1所示,每一个新平台都修正了它前一版本中的不足。


612da4eb737e1941181cfc780aaf03f25e56d164
  • CGI 是Web服务器与返回动态内容的任意可执行程序进行连接的一种标准方法。其规范由美国国家超级计算应用中心(NCSA)维护。

1.1.1 传统的ASP.NET Web Form

ASP.NET在2002年刚问世时,给Web开发领域带来了巨大的转变。图1-1描述了当时微软的技术堆栈。


d7e538804e61c206a8870a7b8a7468f2b7c793a7

(注:此图的含义为,Web Form建立在ASP.NET之上,而ASP.NET又建立在.NET平台之上,MVC所起的作用是替代这里的Web Form。——译者注)

作用于将用户界面(UI)模拟为服务器端控件对象层的办法,微软试图利用Web Form把HTTP(具有无状态本质)和HTML(当时许多开发人员尚不熟悉)都隐藏起来。每个控件在请求期间都跟踪自己的状态(通过View State),在需要时把自己渲染成HTML,并自动地将客户端事件(如按钮点击)与相应的服务器端事件处理代码相关联。结果,Web Form被设计成在Web上传递传统的事件驱动式GUI(图形用户界面)的一个巨大的抽象层。

其思想是,让Web开发在感觉上与Windows Form开发相同。开发者不再需要以一系列独立的HTTP请求和响应进行工作,可以认为它是一种状态化的UI。我们可以忘记Web及其无状态本质,转而用一种“拖—放”式设计器来创建UI,并假想或至少假装,所有事情都发生在服务器上。

1.1.2 SP.NET Web Form表单的问题在哪里

传统的ASP.NET Web Form开发曾是一种了不起的思想,但事实证明它更加复杂。随着时间的推移,Web Form在实际项目中显现出了一些缺陷:

视图状态负荷:跨请求状态维护的实际机制(称为视图状态)导致在客户端与服务器之间传输大块数据。这种数据即使在最适度的Web应用程序中也达到几百KB,而且它来回于每次请求之间,以很长的响应时间令网站访问者不悦,且增加了服务器的带宽需求。

页面生命周期:连接客户端事件与服务器端事件处理代码的机制(是页面的部分生命周期)格外复杂和棘手。很少有开发者在不产生视图状态错误或不发现某些事件处理程序莫明失效的情况下,能够在程序运行期间成功地维护控件层。

关注分离的错误理解:ASP.NET的后台代码模型提供了一种手段,把应用程序代码从它的HTML标记中提取出来,并放到一个独立的后台代码类中。这种逻辑与表现的分离曾得到了广泛的赞许,但在实际应用中,却又鼓励开发者在这些怪异的后台代码类中把表现代码(如操纵服务器端控件树)与它们的应用程序逻辑(如维护数据库数据)混在一起。最终结果是脆弱和难以理解的。

HTML上的受限控制:服务器控件将自己渲染成HTML,但并不是你所希望的那种必要的HTML。在ASP.NET 4之前,这种HTML输出通常不符合Web标准,或不能很好地使用CSS。而且,服务器控件会生成不可预知且复杂的ID值,结果,这些ID难以用JavaScript进行访问。这些问题在ASP.NET 4中减少了,但仍然不容易得到你所期望的HTML。

遗漏抽象:Web Form试图尽可能地隐去HTML和HTTP。当你试图实现自定义行为时,时常需要放弃抽象,这迫使你需要反过来开发回传的事件机制,或采取笨拙的方法,以使它生成所希望的HTML。再则,这种抽象可能对有能力的Web开发者构成一个极大的障碍。

低可测试性:ASP.NET的设计者们恐怕未曾预料到,自动测试会成为软件开发的重要组成部分。因此,他们设计的这种紧耦合体系结构不适合单元测试也就不足为奇了。集成测试也很具挑战性。

ASP.NET一直在不断改进,版本2.0添加了一组标准的应用程序组件,可以减少开发者需要编写的代码量。2007年发布的AJAX是微软对Web 2.0/AJAX疯狂时代的回应,它支持富客户端交互,同时也简化了开发者的工作。最新版的ASP.NET 4能够生成更易于预测且与标准兼容的HTML标记,但依然存在许多内在的局限性。

本文仅用于学习和交流目的,不代表异步社区观点。非商业转载请注明作译者、出处,并保留本文的原始链接。

相关文章
|
18天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
106 45
|
13天前
|
SQL 安全 PHP
探索PHP的现代演进:从Web开发到框架创新
PHP是一种流行的服务器端脚本语言,自诞生以来在Web开发领域占据重要地位。从简单的网页脚本到支持面向对象编程的现代语言,PHP经历了多次重大更新。本文探讨PHP的现代演进历程,重点介绍其在Web开发中的应用及框架创新,如Laravel、Symfony等。这些框架不仅简化了开发流程,还提高了开发效率和安全性。
22 3
|
13天前
|
前端开发 JavaScript 开发工具
从框架到现代Web开发实践
从框架到现代Web开发实践
23 1
|
13天前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
29 1
|
16天前
|
SQL 安全 PHP
探索PHP的现代演进:从Web开发到框架创新
PHP 自发布以来一直在 Web 开发领域占据重要地位,历经多次重大更新,从简单的脚本语言进化为支持面向对象编程的现代语言。本文探讨 PHP 的演进历程,重点介绍其在 Web 开发中的应用及框架创新。自 PHP 5.3 引入命名空间后,PHP 迈向了面向对象编程时代;PHP 7 通过优化内核大幅提升性能;PHP 8 更是带来了属性、刚性类型等新特性。
24 3
|
16天前
|
XML 安全 PHP
PHP与SOAP Web服务开发:基础与进阶教程
本文介绍了PHP与SOAP Web服务的基础和进阶知识,涵盖SOAP的基本概念、PHP中的SoapServer和SoapClient类的使用方法,以及服务端和客户端的开发示例。此外,还探讨了安全性、性能优化等高级主题,帮助开发者掌握更高效的Web服务开发技巧。
|
18天前
|
前端开发 JavaScript
Bootstrap Web 前端 UI 框架
Bootstrap 是快速开发 Web 应用程序的前端工具包。
30 3
|
19天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
31 2
.NetWeb集成cas
仅供参考
782 0
|
2月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
41 7