asp.net webform设计思路的思考

我使用asp.net的webform框架进行web应用程序的开发已经差不多四年了,在整个开发生涯中,也使用过一年asp.net的mvc框架。因为网上经常有讨论webform框架和mvc框架的优劣,所以自己也对这两者进行了关注,因为自己最熟悉webform框架,所以就会考虑它的优势是什么?设计思路是什么?

要理解asp.net的设计思路,必须考虑它的产生年代,产生的技术基础,还有观察同时代其他动态网页技术的特点和思路。

首先是产生asp.net的技术基础,以下援引百度百科:

   “1996年,ASP 1.0(Active Server Pages)版本出现了,它引起了Web开发的新革命,降低了动态网页开发的难度。以前开发动态网页需要编写大量繁杂的C代码,编程效率非常低下,而且需要Web网页开发者掌握非常高的编程技巧。而ASP使用简单的脚本语言,能够将代码直接嵌入HTML,使设计Web页面变得更简单。虽然ASP非常简单,但却能够实现非常强大的功能,这一切得益于其组件。特别是ADO组件,使得在网页中访问数据库易如反掌。这一切推动了动态网页的快速发展与建设,同时使ASP得到迅速流行。

    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(外文名:PHP: Hypertext Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言语法吸收了C语言JavaPerl的特点,利于学习,使用广泛,主要适用于Web开发领域。PHP 独特的语法混合了CJavaPerl以及PHP自创的语法。它可以比CGI或者Perl更快速地执行动态网页。用PHP做出的动态页面与其他的编程语言相比,PHP是将程序嵌入到HTML标准通用标记语言下的一个应用)文档中去执行,执行效率比完全生成HTML标记的CGI要高许多;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。

不管是服务器控件,还是事件驱动,这两种(或者说是一种,因为控件和事件之间本就相互关联)设计思想很大的影响了webform框架,开发web应用程序的方式。服务器控件加事件驱动虽然利于很快开发一个管理系统型web程序,但是并不符合web应用程序本身的运行思想,这一点被很多人批评,web程序因为不运行在桌面操作系统中,最早的时候它甚至不能交互,只是为了便于交流信息,只用于展示信息。web程序本质运行原理是,通过浏览器向web服务器发送请求处理命令,有web托管程序接收请求命令,进行操作,然后返回处理结果(结果可能是展示一篇文章,或者是告诉你文章删除成功,或者是将你提价的信息内容进行了保存)。webform容易让人误会它运行在操作系统或者浏览器中,所有代码执行在客户端。虽然现在的浏览器真的可以将动态页面放在浏览器端执行,但是webform页面其实是有服务器端的程序处理的。

如果要评价和审视webform框架的设计思想,不得不对比另外一个框架思想,那就是mvc的框架(模型)的设计思想。mvc模型的发明,或许不是可以设计,而是对事情的深入思考,然后抓住本质的产物。mvc模型是为了处理问题清晰明了,降低耦合性。

由于不会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框架这些技术背后隐隐有一条思想在串联起来。一个东西的发明不是偶然的,往往有一个不起眼的起始。

阅读本文请注意,假如你感觉混乱,那么就不要阅读引用的部分,可以大概先只阅读其他内容。

本文并没有进行认真的考察和检验,有的地方可能是错误的,一些技术的发明先后也可能并不准确。但是希望文中关注一个技术的发展历史的思路,能给你学习提供一点助益。

原文地址:https://www.cnblogs.com/Tpf386/p/9588243.html

时间: 2024-10-29 19:10:46

asp.net webform设计思路的思考的相关文章

记一次和阿里某总监对话引发的思考:说说你框架的设计思路和优点亮点!

背景: 前不久和阿里的一个技术总监风动聊的时候,他问了这样一个问题:说说你框架的设计思路和优点? 话说,这个问题,5年前开始就一直经常出现在眼前,可我从没认真为它找出过答案! 于是,夜深深,我躺在床上,用笔记本,一边思考,一边打字,试着找寻! 这些年来,我的框架或作品,都快凑满十二个了,每个单独都可以说上好几天. 但如果时间只有半小时,我要怎么介绍呢?介绍哪些呢? 出现在脑海里的框架有三个:CYQ.Data.ASP.NET Aries.Taurus.MVC. 大概是因为近期的精力都在这上面吧的吧

秒杀系统的思考方式与设计思路--左手隔离,右手分层

大家好,我是崔皓. 很高兴有这样一个机会和大家认识.我在IT行业从事软件开发工作十余年了,足迹涵盖企业服务,互联网,企业数字化转型等.工作之余热爱阅读和学习,希望能通过这个专栏和大家成为朋友. 开篇 本次专栏要给大家分享的是"如何设计秒杀系统",专栏共包括15章,本章是第一章.今天会给大家介绍以下内容: 秒杀场景的特征 隔离的设计思路 分层设计思路本章的讲解思路是,提出秒杀场景的特征,也就是理解什么是秒杀.然后介绍在秒杀系统设计的底线,有了底线才能保证进可攻退可守.最后介绍使用哪些方法

Redis设计思路学习与总结

版权声明:本文由宋增宽原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/222 来源:腾云阁 https://www.qcloud.com/community 宋增宽,腾讯工程师,16年毕业加入腾讯,从事海量服务后台设计与研发工作,现在负责QQ群后台等项目,喜欢研究技术,并思考技术演变,专注于高并发业务架构的设计与性能优化. 下半年利用空余时间研究和分析了部分Redis源码,本文从网络模型.数据结构和内存管理.持久化和多机

【转】缓存设计的一些思考

***{转自:缓存设计的一些思考}*** 互联网架构中缓存无处不在,某厂牛人曾经说过:”缓存就像清凉油,哪里不舒服,抹一下就好了”.高品质的存储容量小,价格高:低品质存储容量大,价格低,缓存的目的就在于”扩充”高品质存储的容量.本文探讨缓存相关的一些问题. LRU替换算法 缓存的技术点包括内存管理和替换算法.LRU是使用最多的替换算法,每次淘汰最久没有使用的元素.LRU缓存实现分为两个部分:Hash表和LRU链表,Hash表用于查找缓存中的元素,LRU链表用于淘汰.内存常以Slab的方式管理.

利用Bootstrap+Avalonjs+EntityFramework 开发ASP.NET WebForm应用程序(上)

本文将介绍如何利用Bootstrap+Avalonjs+EntityFramework 开发ASP.NET WebForm应用程序,分为上下两篇.上篇主要介绍实现,下篇主要介绍界面. 打开Visual Studio Web Express2013新建一个空白应用程序 ContactSample--联系人示例 (1)数据库 引入界面文件BootStrap,JS文件jquery和avalon,建立联系人页面Contact.aspx. 打开数据库,设计数据库ContactSample,数据库比较简单,

Backbone设计思路和关键源码分析

一. Backbone的江湖地位: backbone作为一个老牌js框架为大规模前端开发提供了新的开发思路:前端MVC模式,这个模式也是前端开发演变过程中的一个重要里程碑,也为MVVM和Redux等开发思路奠定了夯实的基础,后来的react,vue无不是在backbone的影响下开创出来的经典模式.为什么这么说呢?我们先来回顾下Web前端开发的大概演变流程,本过程纯粹个人理解,抛砖引玉,共同探讨,如有偏差请看官指出错误: 1. 无前端:最早的网页就是HTML,还只是静态页面,当时的脚本含量极少甚

跟张小龙学习做优秀产品经理的设计思路

提起张小龙,大家都非常熟悉这位极度优秀的产品经理,不仅仅是因为Foxmail,更因为目前深刻改变你我移动生活的移动互联网产品 - 微信,其江湖地位的确定已经让众多国内立志于做优秀产品经理的人顶礼膜拜了,我们首先借助互联网材料回顾一下微信的创立历程: 一.微信的演化历程: 2010年11月19日23时58分,张小龙在腾讯微博上写下了这么一句话: 我对iPhone5的唯一期待是,像iPad(3G)一样,不支持电话功能.这样,我少了电话费,但你可以用kik跟我短信,用googlevoice跟我通话,用

asp.net mvc应用架构的思考--Unity的应用及三层代码

最近要做一个项目,和国外的架构师聊过之后.对方提到了他准备采用asp.net mvc, jquery, Unity 等技术来代替老的技术: 如asp.net web form. 他请我帮他想一些关于架构的东西.一直以来,关于asp.net mvc应用的架构,有一些想法.正好借这个机会写出来.资深的人士可能已经知道了,就当是复习吧.欢迎发表意见.指出不足. Unity的应用 Unity出来已经有几年了.早几年的1.2版就可以实现这里所说的功能.目前最新稳定版是2.1.正在开发的3.0也许会给我们带

Hybrid APP架构设计思路

原文:Hybrid APP架构设计思路 关于Hybrid模式开发app的好处,网络上已有很多文章阐述了,这里不展开. 本文将从以下几个方面阐述Hybrid app架构设计的一些经验和思考. 通讯 作为一种跨语言开发模式,通讯层是Hybrid架构首先应该考虑和设计的,往后所有的逻辑都是基于通讯层展开. Native(以Android为例)和H5通讯,基本原理: Android调用H5:通过webview类的loadUrl方法可以直接执行js代码,类似浏览器地址栏输入一段js一样的效果 webvie