我使用asp.net的webform框架进行web应用程序的开发已经差很少四年了,在整个开发生涯中,也使用过一年asp.net的mvc框架。由于网上常常有讨论webform框架和mvc框架的优劣,因此本身也对这二者进行了关注,由于本身最熟悉webform框架,因此就会考虑它的优点是什么?设计思路是什么?javascript
要理解asp.net的设计思路,必须考虑它的产生年代,产生的技术基础,还有观察同时代其余动态网页技术的特色和思路。首先是产生asp.net的技术基础,如下援引百度百科:php
“1996年,ASP 1.0(Active Server Pages)版本出现了,它引发了Web开发的新革命,下降了动态网页开发的难度。之前开发动态网页须要编写大量繁杂的C代码,编程效率很是低下,并且须要Web网页开发者掌握很是高的编程技巧。而ASP使用简单的脚本语言,可以将代码直接嵌入HTML,使设计Web页面变得更简单。虽然ASP很是简单,但却可以实现很是强大的功能,这一切得益于其组件。特别是ADO组件,使得在网页中访问数据库易如反掌。这一切推进了动态网页的快速发展与建设,同时使ASP获得迅速流行。html
1998年,微软公司发布了ASP 2.0,它是做为Windows NT 4 Option Pack的一部分提供的。ASP 2.0与ASP 1.0的主要区别是外部的组件能够初始化,使全部的组件都有了独立的内存空间,而且能够进行事务处理。内置的Microsoft Transaction Server(MTS)使制做组件变得更容易。
2000年6月,微软公司宣布了本身的.NET框架。.NET框架的基本思想是:把原有的重点从链接到互联网的单一网站或设备转移到计算机、设备和服务群组上,而将互联网自己做为新一代操做系统的基础。这样,用户将可以控制信息的传送方式、时间和内容,从而获得更多的服务。
2001年,ASP.NET浮出水面。它最初的名字为ASP+,后来改成ASP.NET。ASP.NET是微软公司开发的一种创建在.NET之上的Web运行环境,它不是ASP的简单升级,而是新一代的Active Server Pages。ASP.NET是微软公司新体系结构Microsoft.NET的一部分,其中全新的技术架构使编程变得更加简单。借助于ASP.NET,能够创造出内容丰富的、动态的、个性化的Web站点。ASP.NET简单易学、功能强大、应用灵活、扩展性好,可使用任何.NET兼容语言。 [4-5]
2002年微软发布.NET正式版本.NET Framework 1.0,其中的ASP版本就是ASP.NET 1.0,在此之前发布了两个.NET测试版本Betal和Beta2。
2003年微软发布了.NET Frameworrk 1.1正式版,其中ASP版本就是ASP.NET 1.1。
2005年微软发布.NET Framework 2.0正式版本,也就是ASP.NET 2.0。”
这是一段引自百度百科,介绍从asp发展到asp.net的记述。阅读这段记述你应该意识到,asp.net是从asp1.0开始发展来的,可是它不是直接从asp发展到asp.net的,首先是asp1.0,而后是asp2.0,而后是asp+,再而后更名为asp.net(这里若是分开看就是asp 、 .net。这是两个词,由于在asp的发展过程当中另外一个大的项目.net出现了,.net为何出现,不在讨论范围,能够自行百度)。asp.net1.1技术的web框架就是webform。
虽然我没打算梳理叙述.net的产生和发展,可是asp.net webform的产生却和.net平台很是紧密。
在asp产生的前两年,产生了另一个很是有名的动态网页技术,那就是PHP。这里援引一下php的概念:
php的产生早于asp技术,asp应该是吸取有php技术的建造思想的,之因此称为建造,是由于php的起点很是低,并无被进行充分的设计,它是从一个小工具快速发展起来的。这里还想提一下另一个重要的动态网页技术,再次援引下百度百科:
“
JSP全名为Java Server Pages,中文名叫java服务器页面,其根本是一个简化的Servlet设计,它 [1] 是由Sun Microsystems公司倡导、许多公司参与一块儿创建的一种动态网页技术标准。JSP技术有点相似ASP技术,它是在传统的网页HTML(标准通用标记语言的子集)文件(*.htm,*.html)中插入Java程序段(Scriptlet)和JSP标记(tag),从而造成JSP文件,后缀名为(*.jsp)。 用JSP开发的Web应用是跨平台的,既能在Linux下运行,也能在其余操做系统上运行。
它实现了Html语法中的java扩展(以 <%, %>形式)。JSP与Servlet同样,是在服务器端执行的。一般返回给客户端的就是一个HTML文本,所以客户端只要有浏览器就能浏览。
JSP技术使用Java编程语言编写类XML的tags和scriptlets,来封装产生动态网页的处理逻辑。网页还能经过tags和scriptlets访问存在于服务端的资源的应用逻辑。JSP将网页逻辑与网页设计的显示分离,支持可重用的基于组件的设计,使基于Web的应用程序的开发变得迅速和容易。 JSP(JavaServer Pages)是一种动态页面技术,它的主要目的是将表示逻辑从Servlet中分离出来。
Java Servlet是JSP的技术基础,并且大型的Web应用程序的开发须要Java Servlet和JSP配合才能完成。JSP具有了Java技术的简单易用,彻底的面向对象,具备平台无关性且安全可靠,主要面向因特网的全部特色。”
JSP技术比php、asp技术产生的更晚,JSP技术如今被用来开发超大型网站,可是并非由于JSP技术自己很是优秀,而是由于它产生于java之上。
这个时代的asp、php、jsp等动态网页技术,都有一个共同点,就是你访问url地址,确定是存在一个这样的文件的。asp.net产生的技术基础是asp,那么asp.net的webform框架使用这同一思想就瓜熟蒂落了。webform的页面文件有两部分,后缀名是.aspx和.aspx.cs两部分组成。这个是有别于asp的,asp页面文件只有一个,后缀名是.asp。从.asp到.aspx咱们能够看到,aspx是在asp的后面加了x字母,联想微软的其余产品,.docx取代.doc、.xlsx取代.xls,多少能够窥探到微软对技术升级的命名思考。
以上叙述,讲到了asp.net webform将页面文件拆分红了两个部分。这是很大的一个改进,这种改进是为了解决一些问题(不是一个,是一系列问题)。改进asp技术cs代码和html混在一块儿,暴露代码细节,asp页面不会被编译成dll。同时也有其余优点。
从asp到asp.net,在webform框架中大量内置了ASP.NET 服务器控件,这是一个很大的改变,这种服务器控件分三种:
- HTML 服务器控件 - 传统的 HTML 标签
- Web 服务器控件 - 新的 ASP.NET 标签
- Validation 服务器控件 - 用于输入验证
网上有人说,这是为了解决开发asp页面会形成意大利面条的问题。个人理解服务器控件的改变远不止于此,假如你建立一个纯服务器控件的页面(asp.net出现不久,不少人就不建议这么干了,至于为何,我知道会生成大量viewstate串,固然还有其余缘由),而后对页面元素进行操做,随着使用的熟练,你可能会意识到webform的页面文件不是在html字符中间拼东西,或者说不是在一堆服务器没法理解的东东中间,动态的生成一些字符。它前进了不少步,它把页面的全部html便签加上标识,通过页面引擎处理,变成了能够被灵活操做的类,程序开发人员能够随意操做这些标签类,而后在一个合适的时候,再将这些类顺序的“ToString()”成字符串,拼到页面上。发明服务器控件技术,做者的思想来源多是桌面应用程序开发技术,从dos操做系统(命令行交互),到视窗操做系统(主要是鼠标点击、键盘按键交互),开发桌面应用程序,会大量使用控件技术,控件复用技术能够大大提高开发效率。为何猜想做者的思想可能来源于此,由于asp技术出现时,当时桌面应用程序开发仍是主流,做者可能浸染在这种氛围内,把桌面应用程序开发的设计思想转移至web程序的开发。这里要引出另一个东西,就是事件驱动,随便新建一个aspx页面,最重要的是事件处理方法,Page_Load。windows操做系统中大量使用事件驱动,是基于“事件驱动模型”的。那么做者在webform中使用事件驱动,也可能借鉴了windows。java
无论是服务器控件,仍是事件驱动,这两种(或者说是一种,由于控件和事件之间本就相互关联)设计思想很大的影响了webform框架,开发web应用程序的方式。服务器控件加事件驱动虽然利于很快开发一个管理系统型web程序,可是并不符合web应用程序自己的运行思想,这一点被不少人批评,web程序由于不运行在桌面操做系统中,最先的时候它甚至不能交互,只是为了便于交流信息,只用于展现信息。web程序本质运行原理是,经过浏览器向web服务器发送请求处理命令,有web托管程序接收请求命令,进行操做,而后返回处理结果(结果多是展现一篇文章,或者是告诉你文章删除成功,或者是将你提交的信息内容进行了保存)。webform容易让人误会它运行在操做系统或者浏览器中,全部代码执行在客户端。虽然如今的浏览器真的能够将动态页面放在浏览器端执行,可是webform页面实际上是有服务器端的程序处理的。web
若是要评价和审视webform框架的设计思想,不得不对比另一个框架思想,那就是mvc框架(模型)的设计思想。mvc模型的发明,或许不是刻意设计,而是对事情的深刻思考,而后抓住本质的产物。mvc模型是为了处理问题清晰明了,下降耦合性。spring
因为不会php和jsp就没办法对比这两种技术了,其实很想把它们也拉进来对比下,特别是jsp技术,由于java的跨平台性,jsp设计时不会有太多windows的影子,windows经常有种不想告诉你复杂的真相,因此我给你包装一个简单的世界给你的感受,而后随着你的成长,这种早期的包装可能会是一个大的负担,或者说微软的东西有太多windows的影子,过于围绕windows了。数据库
最后总结一下,若是你放开本身紧张的神经,不给本身设限,随意联想,随意设计,不过于考虑完美,你会感受到web技术发展中一些思想的传承和变革。从简单的html纯文本展现,文本浏览器的发明,背后的http协议0.9,再到图片展现,LiveScript的发明(就是javascript),到CGI程序,再到Servlet拼接html技术,到php脚本,到asp动态页面技术,到jsp动态页面技术,到webfrom框架,spring框架,mvc框架这些技术背后隐隐有一系列思想在串联起来。一个东西的发明不是偶然的,每每有一个不起眼的起始。编程
阅读本文请注意,假如你感受混乱,那么就不要阅读引用的部分,能够大概先只阅读其余内容。
本文并无进行认真的考察和检验,有的地方多是错误的,一些技术的发明前后也可能并不许确。可是但愿文中关注一个技术的发展历史的思路和方法,能给你学习提供一点助益。