(1) 首先测试HTML,不执行ASP代码。打开Web Matrix,在测试目录下创建一个新的ASPX页面messageHTML.ASPx。如果读者按照第1章的步骤进行,测试目录就是C:\BegASPNET11\ch02\。进入All视图,删除所有已有的代码,再输入下面的代码:
<HTML>
<head>
<title>Inserting ASP.NET code Example</title>
</head>
<body>
Line1: First HTML Line<br />
Line2: Second HTML Line<br />
Line3: Third HTML Line<br />
</body>
</HTML>
(2) 打开浏览器,并访问http://localhost/BegASPNET11/Ch02/messageHTML.ASPx,结果如图2-2所示。

图 2-2
(3) 返回Web Matrix,在All视图中,在页面的顶部添加以下代码:
<script language="VB" runat="server">
Sub Page_Load()
Response.Write ("First ASP.NET Line<br />")
Response.Write ("Second ASP.NET Line<br />")
Response.Write ("Third ASP.NET Line<br />")
End Sub
</script>
<HTML>
<head>
<title>Inserting ASP.NET code Example</TITLE>
</head>
<body>
Line1: First HTML Line<br />
Line2: Second HTML Line<br />
Line3: Third HTML Line<br />
</body>
</HTML>
注意:
<script language="VB" runat="server">一行是Web Matrix自动为每个ASPX页面生成的,所以不必手工输入。即使删除了该行代码,它也会自动出现。但是,如果使用文本编辑器编写页面,就需要在所有ASPX页面的顶部插入这行代码。
(4) 在浏览器的地址栏中输入URL,即http://localhost/BegASPNET11/Ch02/ message ASPXtop.ASPx来观看此示例。此时得到的结果如图2-3所示,但可以看到在HTML上方添加的ASP.NET代码的运行结果。

图 2-3
(5) 返回编辑器,把文件保存为messageASPXbottom.ASPx。现在,将<script>标记之间的代码(包括<script>和</script>标记)剪切下来,并粘贴到body部分的最后,如下所示:
<HTML>
<head>
<title>Inserting ASP.NET code Example</title>
</head>
<body>
Line1: First HTML Line<br />
Line2: Second HTML Line<br />
Line3: Third HTML Line<br />
<script language="VB" runat="server">
Sub Page_Load()
Response.Write ("First ASP.NET Line<br />")
Response.Write ("Second ASP.NET Line<br />")
Response.Write ("Third ASP.NET Line<br />")
End Sub
</script>
</body>
</HTML>
(6) 在浏览器中访问messageASPXbottom.ASPx,注意浏览器仍然先显示ASP.NET代码,如图2-4所示。

图 2-4
代码的说明
首先需说明的是,虽然上面示例采用了ASP.NET代码,但并没有创建动态Web页面,为不同的用户显示不同的页面。这些例子只是说明ASP.NET代码和HTML的执行顺序。需说明的另一个问题是上面的3个例子均以.ASPx为扩展名(尽管第一个页面messageHTML.ASPx只包含HTML代码)。因此,就Web服务器而言,这3个页面都是ASP.NET页面,而且脚本都执行了。这就证明了无论是在纯HTML页面中,还是在ASP.NET页面中,都是以同样方式处理HTML的。
第一个页面messageHTML.ASPx的代码仅显示了一些HTML行和纯文本,浏览器中执行这些代码时,各行将按顺序显示,这一点与我们想像的一样。如下所示:
<HTML>
<head>
<title>Inserting ASP.NET code Example</TITLE>
</head>
<body>
Line1: First HTML Line<br />
Line2: Second HTML Line<br />
Line3: Third HTML Line<br />
</body>
</HTML>
在第二个Web页面(messageASPXtop.ASPx)中,将一些纯HTML、纯文本以及少量的服务器端脚本组合到一起。使用runat = "server"指定在页面传送到浏览器之前,将下面的脚本送到服务器处理。
<script language="VB" runat="server">
Sub Page_Load()
Response.Write ("First ASP.NET Line<br/>")
Response.Write ("Second ASP.NET Line<br/>")
Response.Write ("Third ASP.NET Line<br/>")
End Sub
</script>
ASP.NET代码放在Page_Load()子例程中。当ASP.NET加载页面时,首先执行位于Page_Load()子例程中的所有代码。所以,如果在子例程中放置了要在页面上显示文本的代码,那么在浏览器中,这些文本总是在文件中的HTML文本之前显示,即使把代码放在HTML代码行之后也是如此(如messageASPXBottom.ASPx所示)。ASP.NET代码用Respones.Write语句显示3个ASP.NET行。本书第3章将进一步介绍Response.Write。
下面理解ASP.NET的另一个重要概念。在浏览器中打开messageHTML.ASPx,查看源代码(在Internet Explorer中,单击View | Source)。页面以下面的代码开始:
First ASP.NET Line<br/ > Second HTML Line<br /> Third HTML Line<br />
<HTML>
…
服务器上的ASP.NET模块解释代码Respones.Write,并在服务器上执行显示页面的任务。IIS仅把纯HTML发送给浏览器。因此,在浏览器上不需要任何插件或解释程序。由于不需要修改浏览器,所以任一浏览器都可以显示ASP.NET代码的结果。
最后,把ASP.NET代码移到HTML代码的后面,浏览器仍然先显示ASP.NET的代码。Web浏览器首先扫描文件,看看是否有<script runat = "server">标记。如果有的话,则ASP.NET首先处理<script>标记脚本。由于ASP.NET代码位于Page_load()子例程中,因此一旦加载(创建)页面,就会运行它。所以ASP.NET总是先输出,即使<script>标记没有放在代码页面的顶部也是如此。换言之,服务器根本不理睬<script>标记相对于其他标记元素的位置。
这是重要的一课:如果将ASP.NET码放到位于<script>标记内的Page_load()子例程中,它总是在HTML码之前运行。后面将学习如何执行其他Sub过程。