一年前,当本人拿到一个名叫twig的php程序时,立即被作者oop编程思想所折服,很难想像twig中所有的功能(行事历、邮件、个性化)均在一个php文件(index.php3)中执行完成,这就得益于作者采用了程序代码与页面构架分离的思想,但是我也看到尽管作者做了很大的努力,但由于php的局限性,程序并没有真正做到代码与构架的分离,index.php3这个主文件由于要执行的功能太多,所以其require的模块文件相当之多,至使整个文件依然显得十分零乱,本人愚昧,当时花了半个月的时间,才真正明白程序的构架,分析代码之苦,无人能知啊.
twig程序对我此后的编程有着很大的影响,但是即使这样的作品,依然没有摆脱程序代码与html代码混杂的局面。
程序代码与页面构架的分离是web程序员多年的梦想。在asp.net出现之前,无论是asp、php还是jsp,程序代码与html代码都是混杂在一起的,这种做法,虽然在web技术初期受到赞扬,但是随着时间的的推移,它的弊端是越来越明显,当程序代码很长时,html代码与其混杂,程序的可读性变得很差,让人无法分清程序真正要表示的页面构架。
而新技术asp.net则通过codebehind、用户控件(user control)以及自定义控件(custom control)等方法真正做到了代码的分离。这是一个了不起的进步,大家可以在本文中看到分离代码后的asp.net程序的结构是多么的清晰。
飞刀借此地向大家演示一下它们的具体实现方法,我们先看看要实现的功能。
为了便于理解,这里设计的页面比较简单,页面分为三个主要的部分,头部包含一个adrotator控件(用于显示广告)与一个label控件(用于显示当前广告链接地址);中部是一个登陆页面,包括两个textbox控件(分别用于输入用户名与密码)、一个label控件(显示登陆是否成功)与一个button控件(作为提交按钮);底部包含两个label控件(分别显示当前用户名与用户权限)。
熟悉asp.net的朋友,马上就会意识到头部由于使用了adrotator控件,所以必定存在onadcreated事件以便在label控件显示相应链接;而中部由于使用button控件做为提交按钮,所以必定有一个onclick事件处理。
1 codebehind
首先我们就看看如何使用codebehind方法来实现代码与页面构架的分离,下面给出的源程序是主asp.net程序--example1.aspx:
<% @ page src="cseventhandle.cs" inherits="aspcn" %>
<html>
<head>
<title></title>
</head>
<body>
<form runat="server">
<asp:panel id="header" runat="server">
<asp:adrotator id="ad" advertisementfile="adbannersad.xml" borderwidth="0" onadcreated="adcreated" runat="server" /><br>
当前广告链接:<asp:label id="lbladtext" forecolor="red" runat="server" />
</asp:panel>
<asp:panel id="logon" runat="server">
<table>
<tr><td colspan="2" align="center"><b>登陆窗口</b></td></tr>
<tr><td colspan="2" align="center"><asp:label id="lblmsgshow" forecolor="red" runat="server" /></td></tr>
<tr><td>用户名:</td><td><asp:textbox id="tbusername" runat="server" /></td></tr>
<tr><td>密码:</td><td><asp:textbox id="tbpasswd" textmode="password" runat="server" /></td></tr>
<tr><td><asp:button id="btnsubmit" text="登陆" onclick="submit_click" runat="server" /></td></tr>
</table>
</asp:panel>
<asp:panel id="footer" runat="server">
用户名:<asp:label id="lblusername" font-name="arial" forecolor="red" text="游客" runat="server" />
权限:<asp:label id="lblpurview" font-name="arial" text="无" forecolor="red" runat="server" />
</asp:panel>
</form>
</body>
</html>
例程中,大家可以清楚地看到程序中不包含任何c#、vb、javascript来处理onadcreated与onclick事件,但是执行本程序,程序能够正常使用(如图2-1与图2-2)。这便是使用codebehinde的结果,事件处理已经被转移到其它程序中定义执行。请大家注意本例中第一行的信息:
<% @ page src="cseventhandle.cs" inherits="aspcn" %>
一般在asp.net程序中,page指令都在设定本程序应当使用什么语言(使用language属性),而本例中没有出现language属性,而是出现了两个新的page属性:src与inherits。src属性设定事件处理真正的代码位置,inherits属性则设定需要引入的类名。可以看到本例中定义事件处理的文件是eventhandle.cs,我们来看看它的具体内容:
using system;
using system.data;
using system.data.sqlclient;
using system.web;
using system.web.ui;
using system.web.ui.webcontrols;
using system.web.ui.htmlcontrols;
public class aspcn : page
{
//声明web form中出现的控件
public label lbladtext,lblusername,lblpurview,lblmsgshow;
public textbox tbusername,tbpasswd;
public button btnsubmit;
public adrotator ad;
private string strconnstring = "server=(local)\feidao;database=aspcn;trusted_connection=yes";
//处理adrotator控件建立事件
public void adcreated(object src,adcreatedeventargs e)
{
lbladtext.text = e.alternatetext;
}
public void submit_click(object sender,eventargs e)
{
sqlconnection myconn = new sqlconnection(strconnstring);
myconn.open();
string strusername,strpassword,strselect;
strusername = tbusername.text;
strpassword = tbpasswd.text;
strselect = "select * from bbs_user where id=’"+strusername+"’ and password=’"+strpassword+"’";
sqlcommand mycomm = new sqlcommand(strselect,myconn);
sqldatareader dr = mycomm.executereader();
if(dr.read())
{
//登陆成功
lblmsgshow.text = "登陆成功";
lblusername.text = dr["id"].tostring();
lblpurview.text = dr["purview"].tostring();
}
else
{
//登陆不成功
lblmsgshow.text = "登陆不成功";
}
dr.close();
myconn.close();
}
}
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器