热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

给自定义控件(WebControl)添加事件的几种方法。前两种方法可以不实现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
    
{
        
/**//// 
        
/// 翻页前的页号,不知道这个有没有用
        
/// 

        public Int32 OldPageIndex;

        
/**//// 
        
/// 像要翻到的页号
        
/// 

        public Int32 CurrentPageIndex;
        
    }

  定义委托 #region 定义委托
        
/**//// 
        
/// 定一个委托,翻页的事件
        
/// 

        
/// 
        
/// 

        public delegate void EventPageChange(Object sender, PageArgs e);

        
/**//// 
        
/// 事件用
        
/// 

        protected static readonly object EventChange = new object();

        
/**//// 
        
/// 事件用
        
/// 

        protected static readonly object EventBind = new object();

        
#endregion


        
定义事件 #region 定义事件
        
/**//// 
        
/// 用户单击页号后,触发的事件,在绑定显示数据的控件之前触发
        
/// 

        [Description("页号改变的时候触发")]
        
public event EventPageChange PageChanged
        
{
            add
            
{
                Events.AddHandler(EventChange, value);
            }

            remove
            
{
                Events.RemoveHandler(EventChange, value);
            }

        }


        
/**//// 
        
/// 用户单击页号后,并且绑定显示数据的控件之后触发
        
/// 

        [Description("在自动提取数据的方式下,绑定控件后触发")]
        
public event EventPageChange GridBinded
        
{
            add
            
{
                Events.AddHandler(EventBind, value);
            }

            remove
            
{
                Events.RemoveHandler(EventBind, value);
            }

        }

        
#endregion


        
调用外部事件 #region 调用外部事件
        
/**//// 
        
/// 用户单击页号后,触发的事件,在绑定显示数据的控件之前触发
        
/// 

        
/// 
        
/// 

        protected void OnPageChange(object sender, PageArgs e)
        
{
            EventPageChange hd 
= (EventPageChange)base.Events[EventChange];
            
if (hd != null)
                hd(sender, e);
        }


        
/**//// 
        
/// 绑定控件后触发
        
/// 

        
/// 
        
/// 

        protected void OnGridBinded(object sender, PageArgs e)
        
{
            EventPageChange hd 
= (EventPageChange)base.Events[EventBind];
            
if (hd != null)
                hd(sender, e);
        }

        
#endregion


        
分页控件的回发事件 #region 分页控件的回发事件
        
/**//// 
        
/// 分页控件的回发事件 
        
/// 

        
/// 要翻到的页号

        public void RaisePostBackEvent(string PageIndex)
        
{
            Int32 tmpPageIndex 
= 1//不是数字,显示第一页
            if (Functions.IsInt(PageIndex))
                tmpPageIndex 
= Int32.Parse(PageIndex);

            Pager_Click(tmpPageIndex);
        }

        
#endregion


        
响应分页事件 #region 响应分页事件
        
/**//// 
        
/// 响应分页事件
        
/// 

        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 【增加了使用说明】
这里是分页控件的介绍和源码下载。

推荐阅读
  • Spring Boot 中配置全局文件上传路径并实现文件上传功能
    本文介绍如何在 Spring Boot 项目中配置全局文件上传路径,并通过读取配置项实现文件上传功能。通过这种方式,可以更好地管理和维护文件路径。 ... [详细]
  • Ihavetwomethodsofgeneratingmdistinctrandomnumbersintherange[0..n-1]我有两种方法在范围[0.n-1]中生 ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 本文将详细介绍如何在Webpack项目中安装和使用ECharts,包括全量引入和按需引入的方法,并提供一个柱状图的示例。 ... [详细]
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • 深入解析Android 4.4中的Fence机制及其应用
    在Android 4.4中,Fence机制是处理缓冲区交换和同步问题的关键技术。该机制广泛应用于生产者-消费者模式中,确保了不同组件之间高效、安全的数据传输。通过深入解析Fence机制的工作原理和应用场景,本文探讨了其在系统性能优化和资源管理中的重要作用。 ... [详细]
  • 优化后的标题:深入探讨网关安全:将微服务升级为OAuth2资源服务器的最佳实践
    本文深入探讨了如何将微服务升级为OAuth2资源服务器,以订单服务为例,详细介绍了在POM文件中添加 `spring-cloud-starter-oauth2` 依赖,并配置Spring Security以实现对微服务的保护。通过这一过程,不仅增强了系统的安全性,还提高了资源访问的可控性和灵活性。文章还讨论了最佳实践,包括如何配置OAuth2客户端和资源服务器,以及如何处理常见的安全问题和错误。 ... [详细]
  • Keepalived 提供了多种强大且灵活的后端健康检查机制,包括 HTTP_GET、SSL_GET、TCP_CHECK、SMTP_CHECK 和 MISC_CHECK 等多种检测方法。这些健康检查功能确保了高可用性环境中的服务稳定性和可靠性。通过合理配置这些检查方式,可以有效监测后端服务器的状态,及时发现并处理故障,从而提高系统的整体性能和可用性。 ... [详细]
  • Spring – Bean Life Cycle
    Spring – Bean Life Cycle ... [详细]
  • MySQL Decimal 类型的最大值解析及其在数据处理中的应用艺术
    在关系型数据库中,表的设计与SQL语句的编写对性能的影响至关重要,甚至可占到90%以上。本文将重点探讨MySQL中Decimal类型的最大值及其在数据处理中的应用技巧,通过实例分析和优化建议,帮助读者深入理解并掌握这一重要知识点。 ... [详细]
  • 技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统
    技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统 ... [详细]
  • 本文提出了一种基于栈结构的高效四则运算表达式求值方法。该方法能够处理包含加、减、乘、除运算符以及十进制整数和小括号的算术表达式。通过定义和实现栈的基本操作,如入栈、出栈和判空等,算法能够准确地解析并计算输入的表达式,最终输出其计算结果。此方法不仅提高了计算效率,还增强了对复杂表达式的处理能力。 ... [详细]
  • NFT市场热度持续攀升,波卡能否抓住机遇迎来NFT夏季热潮?
    NFT市场热度持续攀升,波卡能否抓住机遇迎来NFT夏季热潮? ... [详细]
  • 本文介绍了如何利用Struts1框架构建一个简易的四则运算计算器。通过采用DispatchAction来处理不同类型的计算请求,并使用动态Form来优化开发流程,确保代码的简洁性和可维护性。同时,系统提供了用户友好的错误提示,以增强用户体验。 ... [详细]
  • 本指南介绍了 `requests` 库的基本使用方法,详细解释了其七个主要函数。其中,`requests.request()` 是构建请求的基础方法,支持其他高级功能的实现。此外,我们还重点介绍了如何使用 `requests.get()` 方法来获取 HTML 网页内容,这是进行网页数据抓取和解析的重要步骤。通过这些基础方法,读者可以轻松上手并掌握网页数据抓取的核心技巧。 ... [详细]
author-avatar
大乐电摩配销售中心
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有