对于用户控件的使用有这样的特点。就是,当我们要求一个用户控件要实现特定的功能的时候,他可以在整个网站里面的页面上任意拖拽。但是,他的功能相对固定,也就是说在ascx文件中的代码是写死的,一旦要实现其他功能,就要将整个用户控件重做。这里介绍一种方法,要用户控件的可重复使用性更强。
前台代码:
就是一个简单的登录控件
<%@ Control Language="C#" AutoEventWireup="true" CodeFile="LoginControl.ascx.cs" Inherits="LoginControl" %> <table border="1"> <tr> <td colspan="3" style="background-color: #0099ff; text-align: center"> <strong>用户登录</strong></td> </tr> <tr> <td style="width: 100px"> 用户名:</td> <td colspan="2"> <asp:TextBox ID="txtName" runat="server" ValidationGroup="group1"></asp:TextBox></td> </tr> <tr> <td style="width: 100px; height: 30px"> 密码:</td> <td colspan="2" style="height: 30px"> <asp:TextBox ID="txtPassword" runat="server" TextMode="Password"></asp:TextBox></td> </tr> <tr> <td colspan="3" style="text-align: center"> <asp:RequiredFieldValidator ID="RequiredFieldValidator1" runat="server" ControlToValidate="txtName" ErrorMessage="用户名为必填项" ValidationGroup="group1"></asp:RequiredFieldValidator></td> </tr> <tr> <td style="width: 100px"> <asp:Button ID="Button3" runat="server" Text="Button" /></td> <td style="width: 100px; text-align: center"> <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="登录" ValidationGroup="group1" Width="56px" /></td> <td style="width: 100px; text-align: center"> <asp:Button ID="Button2" runat="server" Text="登出" Width="54px" /></td> </tr> </table>
用户控件后台代码
public event EventHandler Authenticate;
protected void Page_Load(object sender, EventArgs e) {
}
public void Button1_Click(object sender, EventArgs e) { if (Authenticate!=null) { Authenticate(this, new EventArgs());//如果用户自定义添加了事件,则该button会按指定的事件进行,而不会走默认事件。相反,会执行默认事件。
} else { string connectString = "Server=. ; DataBase=Test ; uid=sa ; pwd=cosecose "; string selectString = "Select * from userInfo where Name='" + txtName.Text.ToString() + "' and Password='" + txtPassword.Text.ToString() + "'";
SqlConnection conn = new SqlConnection(connectString); conn.Open();
SqlCommand cmd = new SqlCommand(selectString, conn);
SqlDataAdapter sda = new SqlDataAdapter(); sda.SelectCommand = cmd; DataTable dt = new DataTable(); sda.Fill(dt);
if (dt.Rows.Count == 0) { Response.Write("<script>window.alert('密码或用户名输入错误!')</script>"); } else { Response.Write("<script>window.alert('恭喜您,登录成功!')</script>"); } conn.Close(); } }
主页面代码
protected void Page_Load(object sender, EventArgs e) { Button btn =(Button)LoginControl1.FindControl("Button2"); btn.Click += new EventHandler(Show);
//提供第一种方法,通过findcontrol方法找到控件,然后对控件的事件进行添加。
LoginControl1.Authenticate += new EventHandler(Show);
//提供第二种方法,直接绑定上自己的定义事件。 }
protected void Show(object sender ,EventArgs e) { FormsAuthentication.SignOut(); Response.Write("<script>window.alert('用户已经成功退出!')</script>");
|
请发表评论