内联(inline)代码的分离
下面的例子演示了一个简单的带有三个服务器控件(分别是文本框、按钮和标签)的asp.net页面。最初这些控件呈现的内容与html形式是相同的。但是,当你在客户端的文本框中输入值并点击按钮的时候,该页面会发回服务器并且在该页面的代码中处理这个点击事件,动态地更新标签控件的text属性。接下来这个页面会重新呈现以反映更新过的文本。这个简单的例子演示了服务器控件模型背后的基本原理,它使asp.net成为最容易学习和掌握的web编程模型之一。
<%@ page language="vb" %>
<script runat="server">
sub button1_click(byval sender as object, byval e as system.eventargs)
label1.text = "hello " & textbox1.text
end sub
</script>
<html>
<head>
<title>asp.net inline pages</title>
</head>
<body>
<form id="form1" runat="server">
<h1>welcome to asp.net 2.0!</h1>
<b>enter your name:</b>
<asp:textbox id="textbox1" runat="server"/>
<asp:button id="button1" text="click me" onclick="button1_click" runat="server"/>
<br />
<br />
<asp:label id="label1" text="hello" runat="server" />
</form>
</body>
</html>
请注意:上面的例子中的按钮事件处理程序位于包含服务器控件的同一个页面中的<script></script>标记之内。asp.net把这种情况称为页面编程代码内联(code-inline),当你希望在同一个文件中处理代码和显示逻辑的时候,它是非常有用的。但是,asp.net还支持另外一种用于存放你的代码和显示内容的方法,称为后台代码(code-behind)模型。使用后台代码的时候,处理事件的代码位于与服务器控件和标记的页面文件分离的另一个物理上独立的文件之中。当你需要维护这些独立的文件(例如多个人一起建立应用程序)的时候,代码和内容之间的这种清晰的分离是非常有用的。在小组项目中,设计者处理应用程序的ui部分,开发者处理行为或代码是很常见的,后台代码模型适合于这种情况。
简化的后台代码模型
asp.net 2.0为后台代码页面引入了一个改良的运行时(runtime),它简化了页面和代码之间的连接。在新的后台代码模型中,页面被声明为局部(partial)类,允许在运行时把页面和代码文件编译到一个类中。页面代码引用codefile属性和<%@ page %>指令中的后台代码文件,在inherits属性中指定类的名称。请注意,后台代码类的成员必须是公共的(public)或受保护的(protected),不能是私有的(private)。
<%@ page language="vb" codefile="codebehind_vb.aspx.vb" inherits="codebehind_vb_aspx" %>
<html>
<head>
<title>asp.net codebehind pages</title>
</head>
<body>
<form runat="server">
<h1>welcome to asp.net 2.0!</h1>
<b>enter your name:</b>
<asp:textbox id="textbox1" runat="server"/>
<asp:button id="button1" text="click me" onclick="button1_click" runat="server"/>
<br />
<br />
<asp:label id="label1" text="hello" runat="server" />
</form>
</body>
</html>
简化的后台代码模型的优势在于,你不必单独地在后台代码类中声明服务器控件变量。使用局部类(2.0中的新特性)允许aspx页面中的服务器控件id直接被后台代码文件访问。这极大地简化了后台代码页面的维护工作量。 在页面之间共享代码
尽管可以在站点的每个页面中放置代码(使用内联或者后台代码分离模型),还是可能遇到希望在站点的多个页面之间共享代码的情况。把代码复制到需要它的每个页面是一种低效率的和难于维护的方法。幸运的是,asp.net提供了几个让代码供应用程序的所有页面访问的方法。
代码目录
页面可以在运行时动态的编译,代码文件(例如.cs和.vb文件)也可以。asp.net 2.0引入了app_code目录,它可以包含那些含有代码的独立的文件,而这些代码可供应用程序的多个页面访问。asp.net 1.x要求这些共享文件预编译到bin目录中,然而app_code目录中的代码文件将在运行时动态地编译,并供应用程序使用。把多种语言建立的代码文件放在app_code目录中是可行的,这时候应该把它们放在不同的子目录中(在web.config中注册具体语言)。下面的例子演示了使用app_code目录包含一个类文件,页面会调用它。
<%@ page language="vb" %>
<script runat="server">
sub button1_click(byval sender as object, byval e as system.eventargs)
dim c as new customclass
label1.text = c.getmessage(textbox1.text)
end sub
</script>
<html>
<head>
<title>asp.net inline pages</title>
</head>
<body>
<form id="form1" runat="server">
<h1>welcome to asp.net 2.0!</h1>
<b>enter your name:</b>
<asp:textbox id="textbox1" runat="server"/>
<asp:button id="button1" text="click me" onclick="button1_click" runat="server"/>
<br />
<br />
<asp:label id="label1" text="hello" runat="server" />
</form>
</body>
</html>
在默认情况下,app_code目录只能包含相同语言的文件。但是,为了在app_code目录中包含多种语言的文件,你可以把app_code目录划分为多个子目录(每个子目录包含相同语言的文件)。为了实现这个目标,你必须在应用程序的web.config文件中注册每个子目录。
<configuration>
<system.web>
<compilation>
<codesubdirectories>
<add directoryname="subdirectory"/>
</codesubdirectories>
</compilation>
</system.web>
</configuration>
下面的例子演示了一个划分过的app_code目录,它同时包含了vb和c#语言的文件。
<%@ page language="vb" %>
<script runat="server">
sub button1_click(byval sender as object, byval e as system.eventargs)
dim c as new customclass
label1.text = c.getmessage(textbox1.text)
dim c2 as new customclass2
label2.text = c2.getmessage(textbox1.text)
end sub
</script>
<html>
<head>
<title>asp.net inline pages</title>
</head>
<body>
<form id="form1" runat="server">
<h1>welcome to asp.net 2.0!</h1>
<b>enter your name:</b>
<asp:textbox id="textbox1" runat="server"/>
<asp:button id="button1" text="click me" onclick="button1_click" runat="server"/>
<br />
<br />
<asp:label id="label1" runat="server" />
<br />
<asp:label id="label2" runat="server" />
</form>
</body>
</html>
bin目录
asp.net第一版本就支持bin目录,它与code目录类似,只不过它能包含预编译的部件。当你需要使用他人的一些代码的时候,它就非常有用了。在这种情况下,你不需要访问源代码(vb或c#文件),而是使用编译过的dll文件。简单地把部件放在bin目录中就可以使用它了。在默认情况下,bin目录中的所有部件都会被自动地载入应用程序并供页面访问。你需要使用页面顶部的@import指令导入bin目录中的部件的名字空间。
<@ import namespace="mycustomnamespace" >
全局部件缓存
.net框架组件2.0包含了大量的表现框架组件不同部分的部件。这些部件都存储在全局部件缓存中,它是一个可供计算机上所有应用程序(不是供特定的应用程序使用)使用的部件仓库。框架组件中的几个部件会自动地供asp.net应用程序使用。你可以在应用程序的web.config文件中注册额外的部件。
<configuration>
<compilation>
<assemblies>
<add assembly="system.data, version=1.0.2411.0, culture=neutral,
publickeytoken=b77a5c561934e089"/>
</assemblies>
</compilation>
</configuration>
请注意,你还是必须使用@import指令,让单独的页面可以使用这些部件。