在解决方案下创建一个:ASP.NET空WEB应用程序,添加一个WebForm1.aspx页面,在页面里添加一个button控件。然后再添加一个web用户控件,默认名字为WebUserControl1.ascx,这个用户控件其实就是一个容器,但是它确实是一个控件。拖一个button控件到WebUserControl1.ascx里面,Text属性命名为”点击“
双击WebForm1.aspx,点击最下方的”设计,然后再点“”拆分“ 将WebUserControl1.ascx拖动到WebForm1.aspx页面里
将 将WebUserControl1.ascx拖动到WebForm1.aspx页面里后,WebForm1.aspx页的源代码就变成了下面这样
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="事件学习2.WebForm1" %>
<%@ Register src="WebUserControl1.ascx" tagname="WebUserControl1" tagprefix="uc1" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:Button ID="Button1" runat="server" Text="Button" />
<uc1:WebUserControl1 ID="WebUserControl11" runat="server" />
</div>
</form>
</body>
</html>
WebUserControl1.ascx.cs页面
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace 事件学习2
{
public partial class WebUserControl1 : System.Web.UI.UserControl
{
public event EventHandler MyClick; //EventHandler是一个系统自动的委托,这里是定义一个MyClick事件
protected void Page_Load(object sender, EventArgs e)
{
}
protected void Button1_Click(object sender, EventArgs e)
{
MyClick(sender, e); //当点击这个Button1控件,也就是名字为“点击”的这个控件时,触发MyClick事件。为什么事件后面要带两个参数呢?:那是因为调用一个事件,事件一定要和他注册的方法参数一致。而他的注册方法是ResponseMe,本身就带有两个参数的。
}
}
}
WebForm1.aspx.cs页面
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace 事件学习2
{
public partial class WebForm1 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
WebUserControl11.MyClick += ResponseMe; //MyClick事件是定义在WebUserControl11控件类下面的,这里是将MyClick事件注册处理函数
}
public void ResponseMe(object senser, EventArgs e)
{
Button1.Text = "我被点击了"; //处理函数。将WebForm1.aspx页的Button1控件的Text属性赋值
}
}
}