【更正】“给自定义控件(Web Control)添加事件的几种方法”有一个不太准确的地方。

    给自定义控件(Web Control)添加事件的几种方法。前两种方法可以不实现IPostBackEventHandler 
    
    上一篇写了一下如何在自定义控件里面添加事件,由简单的开始,一步一步实现了几种添加事件的方式,由于当时只给自定义控件添加了一种外部事件,测试的时候没有什么问题,但是后来在写分页控件的时候,我给分页控件加了两种外部事件,然后测试的时候就出现了一个问题,本来只想调用外部的一种事件,结果外部的两种事件都被调用了。分析了一下,
public event EventHandler myClick
        {
            add {
                Events.AddHandler(this, value);
            }
            remove {
                Events.RemoveHandler(this, value);
            }
        }

就是这个地方写错了,不能用 this,要单独定义一个 object才行。

    由于上一篇只是一个简单的 demo,我又比较懒,就不去修改了,这里直接把分页控件的事件部分的代码写出来,供大家参考。

    

[Serializable]
    public class PageArgs : EventArgs
    {
        /**//// <summary>
        /// 翻页前的页号,不知道这个有没有用
        /// </summary>
        public Int32 OldPageIndex;

        /**//// <summary>
        /// 像要翻到的页号
        /// </summary>
        public Int32 CurrentPageIndex;
        
    }

 定义委托#region 定义委托
        /**//// <summary>
        /// 定一个委托,翻页的事件
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        public delegate void EventPageChange(Object sender, PageArgs e);

        /**//// <summary>
        /// 事件用
        /// </summary>
        protected static readonly object EventChange = new object();

        /**//// <summary>
        /// 事件用
        /// </summary>
        protected static readonly object EventBind = new object();

        #endregion

        定义事件#region 定义事件
        /**//// <summary>
        /// 用户单击页号后,触发的事件,在绑定显示数据的控件之前触发
        /// </summary>
        [Description("页号改变的时候触发")]
        public event EventPageChange PageChanged
        {
            add
            {
                Events.AddHandler(EventChange, value);
            }
            remove
            {
                Events.RemoveHandler(EventChange, value);
            }
        }

        /**//// <summary>
        /// 用户单击页号后,并且绑定显示数据的控件之后触发
        /// </summary>
        [Description("在自动提取数据的方式下,绑定控件后触发")]
        public event EventPageChange GridBinded
        {
            add
            {
                Events.AddHandler(EventBind, value);
            }
            remove
            {
                Events.RemoveHandler(EventBind, value);
            }
        }
        #endregion

        调用外部事件#region 调用外部事件
        /**//// <summary>
        /// 用户单击页号后,触发的事件,在绑定显示数据的控件之前触发
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void OnPageChange(object sender, PageArgs e)
        {
            EventPageChange hd = (EventPageChange)base.Events[EventChange];
            if (hd != null)
                hd(sender, e);
        }

        /**//// <summary>
        /// 绑定控件后触发
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void OnGridBinded(object sender, PageArgs e)
        {
            EventPageChange hd = (EventPageChange)base.Events[EventBind];
            if (hd != null)
                hd(sender, e);
        }
        #endregion

        分页控件的回发事件#region 分页控件的回发事件
        /**//// <summary>
        /// 分页控件的回发事件 
        /// </summary>
        /// <param name="PageIndex">要翻到的页号</param>
        public void RaisePostBackEvent(string PageIndex)
        {
            Int32 tmpPageIndex = 1; //不是数字,显示第一页
            if (Functions.IsInt(PageIndex))
                tmpPageIndex = Int32.Parse(PageIndex);

            Pager_Click(tmpPageIndex);
        }
        #endregion

        响应分页事件#region 响应分页事件
        /**//// <summary>
        /// 响应分页事件
        /// </summary>
        private void Pager_Click(Int32 tmpPageIndex)
        {
            //判断页号是否超出有效范围
            if (tmpPageIndex < 0)
                tmpPageIndex = 1;

            if (tmpPageIndex > this.PageCount)
                tmpPageIndex = this.PageCount;

            //定义一个事件里的参数
            PageArgs e = new PageArgs();
            e.OldPageIndex = this.PageIndex;
            e.CurrentPageIndex = tmpPageIndex;

            this.PageIndex = tmpPageIndex;

            //触发(调用)外部的事件
            this.OnPageChange(this, e);

            if (this.SetGetDataKind == myPageGetDataKind.Auto)
            {
                //自动提取数据的方式
                //绑定控件
                DataBind(tmpPageIndex);

                //触发(调用)外部的事件
                this.OnGridBinded(this, e);
            }

            //显示UI
            this.ManagerPageUI.AddPageUI();
        }
        #endregion

【开源】QuickPager ASP.NET2.0分页控件V2.0.0.3 【增加了使用说明】
这里是分页控件的介绍和源码下载。

时间: 2024-11-08 21:39:00

【更正】“给自定义控件(Web Control)添加事件的几种方法”有一个不太准确的地方。的相关文章

android为按钮添加事件的三种方法

 Android中为按钮添加事件一般有三种方法,这里总结一下,当然其实这完全是java基础内容. 1.内部类: ? 代码片段,双击复制   btn.setOnClickListener(new OnClickListener() { public void onClick(View v) { ... } });   这种方法适合只为单个按钮添加事件,当按钮较多的时候,就要重复写onClick()方法,这样不是最佳的在做法. 2.创建独立的类: ? 代码片段,双击复制   btn.setOnCli

js 绑定事件的几种方法 addEventListener()

看代码 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>添加事件的几种方法</title> <style type="text/css"> div{ width: 200px; height: 100px; background: #CCCCCC; border: 1px solid #008000; /*dis

js添加事件与选取元素方法

今天学习了几个简单的小效果,主要就是判断语句.随机数.设置元素样式和鼠标事件的学习,今天就拿来和大家分享一下. 第一个是鼠标移入和移出事件,HTML和JS代码如下:  代码如下 复制代码 <div id="main">     <label id="tishi"><input type="checkbox"  />两周内自动登陆</label>     <p id="xinxi&qu

详解jQuery向动态生成的内容添加事件响应jQuery live()方法_jquery

jQuery live()方法是给所有匹配的元素附加一个事件处理函数,即使这个元素是以后通过append,prepend,after等事件生成后的内容也依然有效. 这个方法可以看做是 .bind() 方法的一个变体.使用 .bind() 时,选择器匹配的元素会附加一个事件处理函数,而以后再添加的元素则不会有.为此需要再使用一次 .bind() 才行.比如说: <body> <div class="clickme">Click here</div> &

.net 添加Cookie的4种方法

 这篇文章主要介绍了.net 添加Cookie的4种方法,有需要的朋友可以参考一下 代码如下: //第一种添加Cookie方法         HttpCookie myCookie = new HttpCookie("userrole");         myCookie.Values["a"] = "a";         myCookie.Values[""] = "b";         myCo

Xamarin for android:为button设置click事件的几种方法

原文:Xamarin for android:为button设置click事件的几种方法 在Xamarin中一个最基础的事情,就是为一个button指定click事件处理方法,可是即使是这么一件事也有好几种方法,我在下面列出几种.推荐初学者参考. 注意,1 以下方法并不是全部方法:2 以下方法都是在Activity类中使用.其中方法1.2通常在你的Activity类的OnCreate中调用,且调用前button对象已经初始化. 方法1:使用委托 button.Click += delegate

JS创建事件的三种方法(实例代码)_基础知识

1.普通的定义方式 <input type="button" name="Button" value="确定" onclick="Sfont=prompt('请在文本框中输入红色','红色',' 提示框 '); if(Sfont=='红色'){ form1.style.fontFamily='黑体'; form1.style.color='red'; }" /> 这是最常见的一种定义方式,直接将JS事件定义在需要的

用接口实现事件的一种方法,只是玩玩。

  前一阵子,firelong说,应该用接口实现事件,而不应该用委托.我就希望他能给出一个用接口实现事件的方法,我是一直等呀,等到了现在也没有看到.   昨天又看到了,Snake@Net  说不要把接口和委托给混淆了的文章.也许我就把他们给混淆了吧.他的文章没仔细看,不过我倒是突然想到了一个用接口实现事件的方法,写了一个简单的demo测试了一下,居然还成功了.   所以拿出来抖落抖落.   这个只是体现了一个简单的思路,我并不想用他来证明什么,只是写着玩的.   ================

FLASH中响应键盘事件的四种方法

响应 响应键盘的方法作为AS中的一个重要组成部分,在如今已经越来越广泛的使用,尤其是在 FLASH游戏制作中,如果缺少了响应键盘的方法,那是不可能的,而响应键盘的方法主要的四种,分别是: 1.利用按钮进行检测 2.利用KEY对象 3.利用键盘侦听的方法 4.利用影片剪辑的keyUp和keyDown事件来实现响应键盘 只有熟练掌握了这些方法,然后加以变通的话,就会得到很多意想不到的效果,下面我就结合理论和自己的想法简要的介绍一下. 第一种响应键盘的方法:利用按钮进行检测来实现响应键盘 在按钮的on