科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道ASP.NET 2.0页面框架简要慨述

ASP.NET 2.0页面框架简要慨述

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

ASP.NET Web窗体页面框架组件是一个可缩放的通用语言运行时编程模型,它可以用于动态地生成Web页面。本文介绍ASP.NET页面特性的一些基本知识。

作者:中国IT实验室 来源:中国IT实验室 2007年9月9日

关键字: ASP.NET 框架

  • 评论
  • 分享微博
  • 分享邮件

ASP.NET Web窗体页面框架组件是一个可缩放的通用语言运行时编程模型,它可以用于动态地生成Web页面。ASP.NET页面框架组件是ASP的合理进化(ASP.NET提供的语法与已有的页面是兼容的),它被特意地设计用于解决早期模型中的大量的关键的缺陷。特别是,它提供了建立和使用可供重复使用的(reusable)UI控件的能力,这些控件可以封装公用的功能,从而减少了页面开发者需要编写的代码数量;它使开发者能够清晰有序地构造页面逻辑(并非“缠绕在一起的代码”);它使用的开发工具提供了强大的WYSIWYG(所见即所得)页面设计支持能力(已有的传统ASP代码是不透明的)。本文介绍ASP.NET页面特性的一些基本知识。



编写第一个ASP.NET页面



ASP.NET页面是带.aspx扩展名的文本文件。页面由代码和标记(tag)组成,它们在服务器上动态地编译和执行,为提出请求的客户端浏览器(或设备)生成显示内容。它们可以被部署在IIS虚拟目录树之下。

当浏览器客户端请求.aspx资源的时候,ASP.NET运行时(runtime)对目标文件进行分析,并把它编译成.NET框架类,这个类接下来就可以用于动态地处理请求了(请注意,.aspx文件只在第一次被访问的时候才编译,编译形成的类型实例以后供多个请求重复使用)。



我们不用修改HTML文件中的代码,只需要把它的扩展名改成.aspx,就建立了一个ASP.NET页面。例如,下面的例子演示了一个简单的HTML页面,它收集用户的姓名和类别,当用户点击按钮的时候就把窗体(form)发回原页面:

<form action="intro1_vb.aspx" method="post">

<h3> Name: <input id="Name" type=text>

Category: <select id="Category" size=1>

<option>psychology</option>

<option>business</option>

<option>popular_comp</option>

</select>

<input type=submit value="Lookup">

</h3>

</form>

请注意:当你点击“Lookup”按钮的时候没有发生任何事情,这是由于该.aspx文件只包含了静态HTML(没有动态内容)。因此,相同的HTML被发回到客户端,从而导致窗体字段(文本框和下拉列表)内容丢失。



给页面添加简单的代码



ASP.NET提供的语法与ASP页面是兼容的。它支持<% %>代码呈现(render)块,在.aspx文件中它可以与HTML内容混合使用。在页面显示的时候,这些代码块会严格地执行。



下面的例子演示了如何在HTML中使用<% %>呈现块(每次增加字体的尺寸):

<form action="intro2_vb.aspx" method="post">

<h3> Name: <input id="Name" type=text>

Category: <select id="Category" size=1>

<option>psychology</option>

<option>business</option>

<option>popular_comp</option>

</select>

</h3>

<input type=submit value="Lookup">

<p>

<% Dim I As Integer

For I = 0 to 7 %>

<font size="<%=I%>"> Welcome to ASP.NET </font> <br>

<% Next %>

</form>

  

请注意:上面的例子中的<% %>代码块与ASP不同,它会被真正地编译——而不是由脚本引擎来解释。这改善了运行时的执行性能。



ASP.NET页面开发者可以使用<% %>代码块动态地修改HTML输出信息。例如,下面的代码演示了如何使用<% %>代码块来解释客户端发回的结果:

<form action="intro3_vb.aspx">

<h3> Name: <input name="Name" type=text value="<%=HttpUtility.HtmlEncode

(Request.QueryString("Name"))%>">

Category: <select name="Category" size=1>

<%

 Dim I As Integer

 Dim Values(2) As String

 Values(0) = "psychology"

 Values(1) = "business"

 Values(2) = "popular_comp"

 For I = 0 To Values.Length - 1

%>

<% If (Request.QueryString("Category") = Values(i)) %>

<option selected>

<% Else %>

 <option>

<% End If %>

<%=Values(i)%>

</option>

 <% Next %>

</select>

</h3>

<input type=submit name="Lookup" value="Lookup">

<p>

<% If (Not Request.QueryString("Lookup") = Nothing) %>

Hi <%=HttpUtility.HtmlEncode(Request.QueryString("Name")) %>, you selected: <%

=HttpUtility.HtmlEncode(Request.QueryString("Category")) %>

<% End If %>

</form>

   

请注意:尽管<% %>代码块为我们定制ASP.NET页面返回的文本输出信息提供了强大的途径,但是它们没有提供清晰的HTML编程模型。上面的例子显示,仅使用<% %>代码块的开发者必须自己管理页面的状态、自己截取被发送的值。

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章