客服端控件与服务器控件的区别

上传人:j****9 文档编号:45476459 上传时间:2018-06-16 格式:DOC 页数:22 大小:25.74KB
返回 下载 相关 举报
客服端控件与服务器控件的区别_第1页
第1页 / 共22页
客服端控件与服务器控件的区别_第2页
第2页 / 共22页
客服端控件与服务器控件的区别_第3页
第3页 / 共22页
客服端控件与服务器控件的区别_第4页
第4页 / 共22页
客服端控件与服务器控件的区别_第5页
第5页 / 共22页
点击查看更多>>
资源描述

《客服端控件与服务器控件的区别》由会员分享,可在线阅读,更多相关《客服端控件与服务器控件的区别(22页珍藏版)》请在金锄头文库上搜索。

1、什么时候用什么时候用 html 控件,什么时候用控件,什么时候用“标准控件标准控件“?能不用服务器端控件尽量不用能用 html 控件就不要用 web 控件服务器端控件效率低前两句同意,至于后一句,效率上,纯 html 肯定比 runat=server 低,对于 runat=server ,事实上 内部帮我们作了许许多多的工作,比如在 asp/php/jsp 中需要 /来维护两次 post 之间的状态而帮我们做了这项工作,其内部也是使用 Request.Form 类获取值,然后经过一系列的处理周期( 基于事件驱动)在一个页面上,前者,只是一个字符流的输出,后者涉及对象的创建,控件层次的维护,大

2、量相关页、控件事件同步,ViewState 维护比如必然导致额外的性能损耗,但,它带来的是,【开发效率成倍的提升,完整的组件编程模式.】你不必再一堆的 Request.Form 中绕,你可以引用服务器控件对应,统一的编程模型如1. string txt = Requst.Form“MyTextBoxClientName“;VSstring txt2 = MyTextBoxServerID.Text;2./ jsdocument.form1.action = “?action=delete“/ aspx.csif(Requst.QueryString“action“ = “Delete“) /

3、执行删除操作 .VS / aspx.“) 这么一项工作,同时提供前述的完整的事件模型,便于我们服务器端编程操作【他们最大的诟病就是,假如你启用(默认启用)【ViewState】 来维护状态,那么你一次绑定显示的数据多,页面的大小会成倍的增长】但是,同时,你也注意到,假如我通过 ViewState 来维护状态了,虽然页面变大了,但是多次提交之间,我不必从数据库再加载这些数据了,因为控件会才自动从 ViewState 中自动恢复ViewState 是通过存储在一个隐藏域来实现的,html input hidden 这是我们在 asp/php/jsp 常用的手段的简单的分析之后,你会发现, ASP.

4、NET 就是一个“框架”,包装了很多东西为我们建立了一个统一的 Web 开发模型, 这个模型最重要的就是,事件驱动将客户端事件映射为服务器事件,进而实现类型 Win App 的开发模式!ASP.NET 有太多的特性,没有办法三言两语说清楚,至于性能,你不能简单的说,用服务器控件,效率就低,控件一般是给非专业人士准备的,就是只会拖动鼠标的那些人,专业开发人员很少用的;高手不见得就不用,runat=server, 一个性能优良的应用系统,是需要综合各方面的设计策略的,从 ASP 迁移的过来的,多数会对 产生疑惑,但是相信,具有传统 web 开发经验者,能够很快,理解其本质,了解其内在运行机制,不

5、管如何,他们都离不开最原始的 Requst/Response 这两个对现象!系统性能 与 开发效率 需要一个 tradeoff 的过程,毕竟,我们已经不在 3.5 英寸盘的时代,2004 年末我加一条 256 内存的是,240¥,还是现代的现在 512 的多少 1G 的多少?从应用系统类型看,除了,门户型的信息类网站之外(他们更多使用静态页),简单服务器控件可以放心使用,重量的服务器控件,根据设计策略而定另外,假如基于纯 AJAX ,那看什么框架了,轻量基本的如 AjaxPro,也就没有必要服务器控件了,通过 js + DOM+ dhtml 基本可以完成 UI 绘制了以下转自 CSDN 松鼠发

6、言任何编程模型都有常见的性能缺陷,ASP.NET 也不例外。本节描述一些可避免在代码中出现性能瓶颈的方法。在未使用时禁用会话状态: 并非所有的应用程序或页都要求基于每个用户的会话状态。如果不需要,可将其完全禁用。这可以通过以下页级别指令轻松实现:注意:如果页需要访问会话变量但不创建或修改它们,请将指令值设置为 ReadOnly。还可为 XML Web 服务方法禁用会话状态。请参阅 XML Web 服务一节中的使用对象和内部对象。 慎重选择会话状态提供程序: ASP.NET 为存储应用程序的会话数据提供了三种不同的方法:进程内会话状态、作为 Windows 服务的进程外会话状态和 SQL 数据库

7、中的进程外会话状态。每种方法都有自己的优点,但进程内会话状态是迄今为止速度最快的解决方案。如果仅在会话状态中存储少量易失数据,则应使用进程内提供程序。进程外解决方案主要用于 Web 花园和 Web 农场方案,或用于当服务器/进程重新启动时不能丢失数据的情况。避免与服务器间的过多往返行程:Web 窗体页框架是 ASP.NET 的最佳功能之一,因为它可以显著减少为完成某项任务所需编写的代码量。使用服务器控件和回发事件处理模型的页元素编程访问无疑是最省时的功能。但是,对这些功能的使用存在着适当和不适当的方法,了解何时使用它们是适当的很重要。应用程序通常仅在检索数据或存储数据时才需要往返于服务器。多数

8、数据操作可在往返行程间在客户端进行。例如在用户提交数据前,通常可以在客户端验证窗体项。通常,如果不需要将信息中继回服务器,则不应往返于服务器。如果编写自己的服务器控件,请考虑让它们为上级(支持 ECMAScript)浏览器呈现客户端代码。通过采用“智能”控件,可显著减少对 Web 服务器的不必要点击次数。 使用 Page.IsPostback 避免往返行程上的额外工作:如果处理服务器控件回发,通常需要在第一次请求页时执行代码,该代码不同于激发事件时用于往返行程的代码。如果检查 Page.IsPostBack 属性,则代码可按条件执行,具体取决于是否有对页的初始请求或对服务器控件事件的响应。这样

9、做似乎很明显,但实际上可以忽略此项检查而不更改页的行为。例如: public DataSet ds;.void Page_Load(Object sender, EventArgs e) / .set up a connection and command here. if (!Page.IsPostBack) String query = “select * from Authors where FirstName like %JUSTIN%“; myCommand.Fill(ds, “Authors“); myDataGrid.DataBind(); void Button_Click(O

10、bject sender, EventArgs e) String query = “select * from Authors where FirstName like %BRAD%“; myCommand.Fill(ds, “Authors“); myDataGrid.DataBind(); runat=“server“/Page_Load 事件对所有请求都执行,因此检Page.IsPostBack,以便在处理 Button_Click 事件回发时不执行第一个查询。请注意,即使没有此检查,页的行为也不会改变,因为第一个查询中的绑定会被事件处理程序中的 DataBind 调用推翻。记住,在编

11、写页时会很容易忽略这个简单的性能改进。 谨慎适当地使用服务器控件:尽管服务器控件使用起来非常容易,但它并不总是最佳选择。许多情况下,简单的呈现或数据绑定替换可以完成同样的事情。例如: public String imagePath;void Page_Load(Object sender, EventArgs e) /.retrieve data for imagePath here.DataBind();The path to the image is: runat=“server“/ runat=“server“/The path to the image is: /The path to

12、 the image is: /在此示例中,不需要服务器控件将值代入发送回客户端的结果 HTML。在许多其他情况下此方法同样适用,甚至在服务器控件模板中。但是,如果要以编程方式操作控件属性、从中处理事件或利用其状态保存,则服务器控件更合适。应检查服务器控件的使用,并查找可优化的代码。避免过多的服务器控件视图状态:自动状态管理是一种功能,它使服务器控件能够在往返行程中重新填充它们的值,而不要求编写任何代码。但是,此功能并不能任意使用,因为控件状态是在隐藏的窗体字段中传入和传出服务器的。应当明 ViewState 何时有帮助,何时没有。例如,如果在每个往返行程中将控件绑定到数据(如第四条提示中的数

13、据网格示例所示),则不要求控件维护它的视图状态,因为无论如何都将擦除任何重新填充的数据。默认情况下,为所有的服务器控件启用 ViewState。若要禁用它,请将控件的 EnableViewState 属性设置为 false,如下例所示: 还可在页级别关闭 ViewState。这在根本不从页回发时非常有用,如下例所示: 注意,User Control 指令也支持此属性。若要分析页上的服务器控件使用的视图状态量,请启用跟踪并查看“控件层次结构”表中的“视图状态”列。有关跟踪功能及如何启用它的更多信息,请参阅应用程序级别的跟踪记录功能。对字符串连接使用 Response.Write:在页面或用户控件

14、中对字符串连接使用 HttpResponse.Write 方法。该方法提供非常有效的缓冲和连接服务。但是,如果您打算执行大量的连接,则使用下列示例中的方法(即多次调用 Response.Write)来连接字符串比仅调用一次 Response.Write 方法要快。 Response.Write(“a“);Response.Write(myString);Response.Write(“b“);Response.Write(myObj.ToString();Response.Write(“c“);Response.Write(myString2);Response.Write(“d“);不要依赖

15、代码中的异常:异常非常浪费资源,应在代码中尽量避免。绝不要将异常作为控制常规程序流的方法。如果可以在代码中检测到会导致异常的条件,就应该那样做,而不要等到捕捉异常后再处理该条件。常见的方案包括:检查空值,分配给将分析为数字值的字符串,或在应用数学运算前检查特定值。例如: / Consider changing this:try result = 100 / num;catch (Exception e) result = 0;/ To this::if (num != 0)result = 100 / num;elseresult = 0;将大量调用的 COM 组件移植为托管代码:.NET 框

16、架一种非常容易的方法与传统的 COM 组件相互操作。其优点是可以在保留现有代码的同时利用新的平台。但是,在某些情况下,保留旧组件的性能成本超出了将组件迁移到托管代码的费用。每种情况都非常特别,而决定所需更改的内容的最佳方法是测量站点的性能。但是,通常 COM 交互性的性能影响与函数调用的次数或从非托管代码封送到托管代码的数据量成比例。由于各层间的通讯数,需要同大量调用交互的组件称为“chatty”。应考虑将这种组件移植为完全托管的代码,以从 .NET 平台提供的性能收益中获益。或者可以考虑重新设计组件,以请求更少的调用或一次封送更多数据。将 SQL 存储过程用于数据访问:在 .NET 框架提供的所有数据访问方法中,基于 SQL 的数据访问是生成性能最好的可缩放 Web 应用程序的最佳选择。使用托管 SQL 提供程序时,可通

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 中学教育 > 初中教育

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号