之前一直写MVC的,本来就不大喜欢.NET中的服务器控件,里面的缺点很多,但有时候用起来方便,而且现在的项目开发中也要用到。
所以就找了好多资料来看一下,现在做一下记录。
下面给出例子,一个用户登陆的用户控件,里面外加了个自定义事件按钮。
用户控件效果图:
给出用户控件中的代码
代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace Dome
{
//声明一个委托
public delegate void ClickEventHandler(object sender, EventArgs e);
public partial class Login : System.Web.UI.UserControl
{
public string UserName
{
get { return txtUserName.Text; }
set { txtUserName.Text = value; }
}
public string PassWord
{
get { return txtPassWord.Text; }
set { txtPassWord.Text = value; }
}
//可用按钮
public Button LoginButton
{
get { return this.SubmitLogin; }
set { this.SubmitLogin = value; }
}
protected void Page_Load(object sender, EventArgs e)
{
//加载方法
test();
}
//可用方法
public void test()
{
Response.Write("方法输出<br>");
}
protected void SubmitLogin_Click(object sender, EventArgs e)
{
Response.Write("登陆原有事件<br>");
}
//声明单击事件
public event ClickEventHandler Click;
//判断事件是否被订阅
protected void OnClick(EventArgs e)
{
if (Click != null)
Click(this, e);
}
protected void SubmitLogin0_Click(object sender, EventArgs e)
{
Response.Write("用户自定义控件原来的!<br>");
//调用事件
this.OnClick(e);
}
}
}
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace Dome
{
//声明一个委托
public delegate void ClickEventHandler(object sender, EventArgs e);
public partial class Login : System.Web.UI.UserControl
{
public string UserName
{
get { return txtUserName.Text; }
set { txtUserName.Text = value; }
}
public string PassWord
{
get { return txtPassWord.Text; }
set { txtPassWord.Text = value; }
}
//可用按钮
public Button LoginButton
{
get { return this.SubmitLogin; }
set { this.SubmitLogin = value; }
}
protected void Page_Load(object sender, EventArgs e)
{
//加载方法
test();
}
//可用方法
public void test()
{
Response.Write("方法输出<br>");
}
protected void SubmitLogin_Click(object sender, EventArgs e)
{
Response.Write("登陆原有事件<br>");
}
//声明单击事件
public event ClickEventHandler Click;
//判断事件是否被订阅
protected void OnClick(EventArgs e)
{
if (Click != null)
Click(this, e);
}
protected void SubmitLogin0_Click(object sender, EventArgs e)
{
Response.Write("用户自定义控件原来的!<br>");
//调用事件
this.OnClick(e);
}
}
}
下面是引用页面的代码
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="Dome.WebForm1" %>
<%@ Register src="Controls/Login.ascx" tagname="Login" 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>
<uc1:Login ID="Login1" runat="server" />
</div>
</form>
</body>
</html>
<%@ Register src="Controls/Login.ascx" tagname="Login" 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>
<uc1:Login ID="Login1" runat="server" />
</div>
</form>
</body>
</html>