意圖是這樣的:
管理頁面中,總會(huì)有一些新增啊,刪除啊,修改啊之類的按鈕,為了方便,我想做個(gè)用戶控件;
這個(gè)用戶控件,里面有三個(gè)按鈕,新增、修改、刪除;這個(gè)用戶控件要在多個(gè)頁面上出現(xiàn),當(dāng)然,修改與刪除的對(duì)像也不相同;所以,這個(gè)用戶控件,在不同的頁面中,這三個(gè)按鈕會(huì)使用不同的事件;
(如果只是加事件,直接雙擊按鈕就可以加了)
用戶控件的代碼
<%@ Control Language="C#" AutoEventWireup="true" CodeFile="UserLogin.ascx.cs" Inherits="UserLogin" %>
<html xmlns="http://www./1999/xhtml" >
<body>
<table border="1">
<tr>
<td>用戶名:</td>
<td><asp:TextBox ID="txt1" runat="server"></asp:TextBox></td>
</tr>
<tr>
<td>密 碼:</td>
<td><asp:TextBox ID="txt2" TextMode="password" runat="server"></asp:TextBox></td>
</tr>
<tr>
<td><asp:Button ID="ButAdd" runat="server" Text="新增" OnClick="ButAdd_Click" />
<asp:Button ID="ButMod" runat="server" Text="修改" OnClick="ButMod_Click" />
<asp:Button ID="ButDel" runat="server" Text="刪除" OnClick="ButDel_Click" />
</td>
<td><asp:LinkButton ID="LinkButton1" Text="登陸" OnClick="MyOnClick" runat="server" ></asp:LinkButton></td>
</tr>
</table>
</body>
</html>
用戶控件C#中的代碼
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
//using System.Collections.Generic;
//using System.Text;
public partial class UserLogin : System.Web.UI.UserControl
{
protected void Page_Load(object sender, EventArgs e)
{
}
//添加屬性
public string UserName
{
get { return txt1.Text; }
set { txt1.Text = value; }
}
//添加屬性
public string PassWord
{
get { return txt2.Text; }
set { txt2.Text = value; }
}
//定義一個(gè)委托
public delegate void userEvent(object sender, EventArgs arg);
//
//添加事件
public event userEvent Login; //添加事件句柄
protected void MyOnClick(object Sender, EventArgs e)
{
if (Login != null)
Login(this, new EventArgs()); //激活Login事件
}
////定義一個(gè)委托
//public delegate void userEvent(object sender, EventArgs arg);
////
//添加三個(gè)事件
public event userEvent Add;
public event userEvent Delete;
public event userEvent Modify;
//
#region 控件中按鈕的事件
protected void ButAdd_Click(object sender, EventArgs e)
{
if (this.Add != null)
this.Add(this, e);
}
protected void ButDel_Click(object sender, EventArgs e)
{
if (this.Delete != null)
this.Delete(this, e);
}
protected void ButMod_Click(object sender, EventArgs e)
{
if (this.Modify != null)
this.Modify(this, e);
}
#endregion
}
上面用到了事件與委托;利用用戶控件中的按鈕來觸發(fā)自己定義的事件;
那么,在aspx頁面中引用這個(gè)控件時(shí):
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<%@ Register Src="UserLogin.ascx" TagName="UserLogin" TagPrefix="uc1" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www./TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www./1999/xhtml" >
<head runat="server">
<title>無標(biāo)題頁</title>
</head>
<body style="margin-left:0px">
<form id="form1" runat="server">
<div>
<uc1:UserLogin ID="UserLogin1" OnAdd="ButAdd_Click" OnDelete="ButDel_Click" OnModify="ButMod_Click" OnLogin="OnLoginPress" runat="server" />
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
<asp:TextBox ID="TextBox2" runat="server"></asp:TextBox></div>
</form>
</body>
</html>
在這個(gè)aspx頁面的C#文件中,有這樣一些事件
protected void OnLoginPress(Object Render, EventArgs e)
{
TextBox1.Text = UserLogin1.UserName;
TextBox2.Text = UserLogin1.PassWord;
}
protected void ButAdd_Click(object sender, EventArgs e)
{
//this.Response.Write(sender.GetType().ToString());
TextBox1.Text = "添加了數(shù)據(jù)!";
}
protected void ButDel_Click(object sender, EventArgs e)
{
TextBox1.Text = "我已刪除";
//this.Response.Write("刪除");
}
protected void ButMod_Click(object sender, EventArgs e)
{
TextBox1.Text = "修改了數(shù)據(jù)!";
//this.Response.Write("修改");
}
那么,在不同的aspx文檔中,我就可以寫不同的事件了;很簡(jiǎn)單吧;
這樣,我們還可以在用戶控件中判斷當(dāng)前登錄用戶的權(quán)限,例如,如果沒有刪除權(quán)限,刪除按鈕就不出現(xiàn);