技术开发 频道

编写ASP.NET应用程序的十大技巧

  

  6. HyPerlink控件、LinkButton控件的差别
 
  对于Web访问者而言,HyperLink、LinkButton控件是一样的,但它们在功能方面仍然有较大的差异。当用户点击控件时,HyperLink控件会立即将用户导航到目标URL,表件不会回送到服务器上。LinkButton控件则首先将表件发回到服务器,然后将用户导航到目标URL。如果在到达目标URL之前需要进行服务器端处理,则使用LinkButton控件;如果无需进行服务器端处理,则可以使用HyperLink控件。
 
  7、注释代码
 
  这一技巧并不是针对ASP.NET的,但它是一个良好的编程习惯。注释不仅仅应当说明代码会执行什么操作,还应当注明原因。例如,不要仅仅在注释中说明是在遍历数组,而是要说明遍历数组是根据某一算法计算一个值,除非算法是相当简单的,否则还应当对算法进行简要的说明。

  .NET工程中的不同的编程语言都有各自不同的注释符号,下面是一个简要的说明:

HTML <!-- 注释 -->
JavaScript // 注释
VBScript 注释
VB.net 注释
C# // 注释
/* 多行内容
的注释
*/
SQL -- 注释 

  在服务器控件的开始和结束标记中没有注释符号,但服务器能够忽略掉所有它不能识别的属性,因此我们能够通过使用没有定义的属性来插入注释。下面是一个例子:

<asp:TextBox id=”txtLastName” size=”40” comment=”这是我的注释” runat=”server” />
  
  Visual Studio .NET中对源代码进行注释非常简单。高亮度显示需要注释的行,然后按Ctrl+K+C组合键添加注释。要删除注释,只需高亮度显示被注释的代码,并按下Ctrl+K+U组合键。
 
  在C#工程中,我们还可以通过在每行的开始处使用///输入XML注释小节。
 
  在注释小节中,我们可以使用下面的XML标记组织注释:

 

 

  <summary></summary>
  <remarks></remarks >
  <param></param>
  <returns></returns>
  <newpara></newpara>

  要在Visual Studio .NET中查看这些XML注释的格式化的报告,我们可以首先选择工具菜单项,然后选择建立注释Web网页菜单项。
 
   8、使用trace方法和trace属性记录Page目录中网页的执行情况
 
  调试程序的一种古老的技术是在程序中的关健点插入输出语句,通常情况下,输出信息中会包含重要变量的值,相关信息可以输出到屏幕、日志文件或者数据库。
 
  在ASP.net中,通过使用Page命令中的trace属性,这种调试技术的使用更简单了。Page命令是ASPX文件开始处的一行代码,它提供编译器的指示。Page命令中包含一个或多个属性,向编译器提供使用的编程语言、代码支持文件的位置或要继承的类的名字等信息。
 
  Page命令中的属性之一是trace,其值可能是true或false,下面是一个典型的Page命令,其中的trace属性的值是true:
<%@ Page language="C#" trace="true" %>
  
   如果trace属性的值设置为true,由ASPX文件生成的Web页就会显示出来,除了网页本身外,关于该页的大量其他信息也会显示出来。这些信息以下面小节的形式显示在一张表格中:
 
  ·Request细节 提供Session ID、请求时间和请求的状态码。
 
  ·Trace Information 包含跟踪日志、网页生命周期中按时间先后顺序各个步骤的列表。另外,也可以向其中添加定制信息。
 
  ·控件树 以一种分层次的方式列出网页上的所有控件,包括每个控件以字节计算的大小。
 
  ·Cookies集合 列出该网页创建的所有Cookie。
 
  ·头部集合 HTTP头部以及它们的值。
 
  ·Server变量 与该网页相关的Server环境变量。
 
  包含在Trace Information小节中的跟踪日志是最有用的,在这里我们可以插入自己的跟踪命令。trace类中有2个方法能够在跟踪日志中插入命令:Trace.Write和Trace.Warn,除了Trace.Warn命令用红色字体显示、Trace.Write命令用黑色字体显示外,它们是相同的。下面是跟踪日志的一个屏幕快照,其中包含有几个Trace.Warn命令。
 
  跟踪日志中最方便的功能是我们可以在开发和测试过程中在整个代码中插入Trace.Write和Trace.Warn语句,而在最终交付应用程序时,可以通过改变Page命令中trace属性的值,禁止这些命令起作用,而无需在部署应用软件前删除这些输出语句。
 
     9、使用存储过程
 
  微软公司的SQL Server和其他现代关系数据库都使用SQL命令定义和处理查询。一个SQL语句或一系列SQL语句提交给SQL Server,SQL Server会对命令进行解析,然后创建一个查询计划并对它进行优化,然后执行该查询计划,这都需要大量的时间。
 
  存储过程是一系列被查询处理器预解析和优化的SQL命令,这些命令会被存储起来,可以得到快速地执行。存储过程也被称作sprocs,它可以接收输入参数,使一个单一的存储过程能够处理较大范围的特定的查询。
 
  因为sprocs是预先被解析的,对于复杂的查询更显得重要,其查询计划是预先优化的,因此调用查询过程比执行相同功能的SQL语句速度要快得多。
 
      10、使用.NET命令行
 
  .NET命令行工具在命令提示符窗口中运行。为了使命令能够执行,它必须驻留在命令提示符的当前目录中,或通过设置PATH环境变量。
 .NET SDK在启动菜单上安装一个菜单项,该菜单项能够打开一个正确设置了PATH环境变量的命令提示符窗口。我们可以通过依次点击开始->程序->Microsoft Visual Studio .NET->Visual Studio .NET工具->Visual Studio .NET命令提示符,启动命令提示符窗口。
 
  通过在将该菜单项从菜单上拖到桌面上时,同时按Ctrl+C键,就可以将该菜单项的快捷方式拷贝到桌面上,使用起来会非常方便。
0
相关文章