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

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

     给自定义控件(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 【增加了使用说明】
这里是分页控件的介绍和源码下载。
相关文章
|
6月前
|
JSON 缓存 Go
Golang 语言 Web 框架 beego v2 之控制器方法和输入输出数据
Golang 语言 Web 框架 beego v2 之控制器方法和输入输出数据
51 0
|
7月前
|
安全 中间件 Apache
【Web安全】不安全的HTTP方法
围绕渗透攻防层面来看不安全的HTTP方法漏洞的检测发现修复等手法。
273 1
|
8月前
vite环境引入web worker方法
在 vite 环境中使用 web worker 时,如果遇到生产环境中 worker.js 文件的 MIME 类型被识别为 text/html,导致报错无法运行的情况时,可以参考以下两种方法,原理都是避免编译时产出单独的 worker.js 文件。方法一worker文件不需要包装,引入时后缀增加 ?worker&inline,使用时直接 new ImportedWorker();self.
436 0
|
1月前
|
安全 测试技术 API
请描述在 Python WEB 开发中常用的测试方法。
请描述在 Python WEB 开发中常用的测试方法。
18 0
|
2月前
|
JavaScript 前端开发 API
「深入探究Web页面生命周期:DOMContentLoaded、load、beforeunload和unload事件」
在 Web 开发中,了解页面生命周期是非常重要的。页面生命周期定义了页面从加载到卸载的整个过程,包括各种事件和阶段。在本文中,我们将详细介绍四个关键事件:DOMContentLoaded、load、beforeunload 和 unload。我们将探讨这些事件的属性、API、应用场景,并提供一些代码示例和参考资料。
|
3月前
|
Web App开发 前端开发 JavaScript
Web前端性能测试方法
Web前端性能测试方法
|
3月前
|
移动开发 前端开发 JavaScript
web前端之ES6的实用深度解构赋值方法、复杂的解构赋值
web前端之ES6的实用深度解构赋值方法、复杂的解构赋值
29 1
|
3月前
|
搜索推荐 应用服务中间件 Apache
HTTP状态码301(永久重定向)不同Web服务器的配置方法
当用户或搜索引擎向服务器发出浏览请求时,服务器返回的HTTP数据流中头信息(header)中包含状态码301,以向用户表示该资源已经永久改变了位置。
89 2
|
5月前
|
存储 移动开发 搜索推荐
Web开发中会话跟踪的方法有哪些?
Web开发中会话跟踪的方法有哪些?
31 0
|
5月前
|
Web App开发 Linux UED
Web 网站 LCP 性能指标的度量方法
Web 网站 LCP 性能指标的度量方法
52 1