为ASP.NET WEB自定义控件添加提交事件

ASP.NET WEB自定义控件添加提交事件

顾庆岗 prettywolf@vip.sina.com

Visual Studio.Net提供的服务端控件中有一个叫做“LinkButton”的,它看上去像个链接可是点击时产生像Button一样的Click提交事件。那么我们自己做的自定义控件如何实现这一功能呢?下面的代码讲述这一功能的实现。

1. 首先创建一个Web自定义控件项目命名为Demo,空间源代码文件命名为DemoLinkButton

2. public class DemoLinkButton : System.Web.UI.WebControls.WebControl,IPostBackEventHandler 控件类继承System.Web.UI.WebControls.WebControl并实现接口IPostBackEventHandler中的方法:RaisePostBackEvent( string )。

3. 修改Text属性。

[Bindable(false),

              Category("Appearance"),

              DefaultValue("")]

         public string Text

         {

              get

              {

                   string _text = (string)ViewState["Text"];

                   return _text == null ? "" : _text;

              }

              set

              {

                   ViewState["Text"] = value;

              }

         }

4. 向页面注册处理提交的Javascript代码。

protected override void OnPreRender(EventArgs e)

         {//产生使页面提交的Javascript函数,这个函数要用到Hyperlink的href中。

              string scriptClick="<script language='javascript'>function DoOnClick(){"+((HyperLinkClicked==null)?"":(Page.GetPostBackClientEvent(this,"Clicked"))+"; return;}</script>");

              Page.RegisterClientScriptBlock("OnClicked",scriptClick);

         }

5. 向页面输出控件显示。

protected override void Render(HtmlTextWriter output)

         {

              if(this.Text == "")

              {

                   output.Write("<a href=/"javascript:DoOnClick();/" id=/"" +this.ClientID+ "/">DemoLinkButton</a>");

              }

              else

              {

                   output.Write("<a href=/"javascript:DoOnClick();/" id=/"" +this.ClientID+ "/">"+this.Text+"</a>");

              }

         }

6. 最后实现IPostBackEventHandler接口。

public void RaisePostBackEvent(string eventArgument)

         {

              if (eventArgument=="Clicked") HyperLinkClicked(this,EventArgs.Empty);

         }

这样一个自定义回发事件的控件就完成了,与类库中的LinkButton基本相似,点击链接产生提交事件,在代码页处理HyperLinkClicked事件就可以了。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值