【更正】“给自定义控件(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 【增加了使用说明】
这里是分页控件的介绍和源码下载。
相关文章
|
2月前
|
SQL 存储 安全
Web 常见攻击方式及防御方法
【10月更文挑战第25天】Web 安全是一个复杂而重要的领域,攻击者不断寻找新的攻击方法,我们需要不断加强防御措施,提高安全意识,以保障 Web 应用的安全运行。通过采取多种防御手段的综合运用,我们可以有效地降低 Web 攻击的风险,保护用户的信息和财产安全。同时,随着技术的不断发展,我们也需要持续关注和研究新的安全威胁和防御方法,以应对不断变化的安全形势。
342 56
|
2月前
|
存储 安全 Go
Web安全基础:防范XSS与CSRF攻击的方法
【10月更文挑战第25天】Web安全是互联网应用开发中的重要环节。本文通过具体案例分析了跨站脚本攻击(XSS)和跨站请求伪造(CSRF)的原理及防范方法,包括服务器端数据过滤、使用Content Security Policy (CSP)、添加CSRF令牌等措施,帮助开发者构建更安全的Web应用。
115 3
WEB端在线CAD中实现测量圆、测量面积的方法
实现在线CAD中测量圆和测量面积的功能开发,用户点击目标圆对象将自动标记出这个圆的半径、面积值和周长值,同时可以自定义选择标注文字的位置,测量圆功能能够快速掌握目标圆对象的数据信息,方便统计工程量。
WEB端在线CAD中实现测量圆、测量面积的方法
|
3月前
|
前端开发 JavaScript
掌握微前端架构:构建现代Web应用的新方法
本文介绍了微前端架构的概念及其在现代Web应用开发中的优势与实施方法。微前端架构通过将应用拆分成独立模块,提升了开发效率和灵活性。其核心优势包括技术栈灵活性、独立部署、团队协作及易于维护。文章详细阐述了定义边界、选择框架、管理状态和通信等关键步骤,并讨论了状态同步、样式隔离及安全性等挑战。微前端架构有望成为未来Web开发的重要趋势。
|
3月前
|
存储 前端开发 API
前端开发中,Web Storage的存储数据的方法localstorage和sessionStorage的使用及区别
前端开发中,Web Storage的存储数据的方法localstorage和sessionStorage的使用及区别
143 0
|
4月前
|
前端开发 JavaScript 持续交付
Web应用开发的方法
Web应用开发的方法
39 1
|
5月前
|
JavaScript 前端开发 开发者
JS 继承之谜:究竟有哪些神秘方法?Web 前端开发者必知的关键技巧待你揭开谜底!
【8月更文挑战第23天】JavaScript (JS) 是 Web 前端开发的关键语言,其中继承是面向对象编程的重要概念。本文探讨了 JS 中几种继承机制:原型链继承、构造函数继承及组合继承。原型链继承利用原型对象实现属性和方法的共享;构造函数继承通过在子类构造器内调用父类构造器实现私有属性的复制;组合继承结合两者优点,既支持属性共享又避免了属性被意外覆盖的风险。理解这些模式有助于开发者更高效地组织代码结构,提升程序质量。
36 1
|
5月前
|
前端开发 开发者 安全
JSF表单处理大揭秘:数据绑定与事件处理,如何让Web应用更加智能?
【8月更文挑战第31天】在现代Web应用开发中,JSF(JavaServer Faces)框架因强大的表单处理能力而广泛应用。其数据绑定机制可实现表单控件与后端模型的双向传输,降低前后端耦合度,提高代码维护性和类型安全性。事件处理机制则支持丰富的内置与自定义事件,进一步增强应用灵活性。本文通过示例代码展示这些特性,帮助开发者更好地利用JSF构建高效、灵活的Web应用。然而,JSF也存在组件库较小和学习成本较高等局限,需根据具体需求权衡使用。
55 0
|
5月前
|
Java 开发者 关系型数据库
JSF与AWS的神秘之旅:如何在云端部署JSF应用,让你的Web应用如虎添翼?
【8月更文挑战第31天】在云计算蓬勃发展的今天,AWS已成为企业级应用的首选平台。本文探讨了在AWS上部署JSF(JavaServer Faces)应用的方法,这是一种广泛使用的Java Web框架。通过了解并利用AWS的基础设施与服务,如EC2、RDS 和 S3,开发者能够高效地部署和管理JSF应用。文章还提供了具体的部署步骤示例,并讨论了使用AWS可能遇到的挑战及应对策略,帮助开发者更好地利用AWS的强大功能,提升Web应用开发效率。
76 0
|
5月前
|
前端开发 JavaScript 开发者
掌握Web前端事件处理精髓:从事件冒泡到事件委托,轻松优化你的交互体验与代码性能!
【8月更文挑战第23天】在Web前端开发中,事件处理是实现用户交互的关键机制。其中,事件冒泡与事件委托是优化页面性能、简化代码的重要手段。事件冒泡是指事件从触发它的元素开始,沿着DOM树向上逐层传播至根节点的过程。通过阻止事件冒泡,可以控制事件的影响范围。而事件委托则是利用事件冒泡特性,在父元素上设置监听器来响应子元素的事件,这种方法减少了监听器的设置数量,特别适用于动态添加的子元素,提高了代码的可维护性和性能。掌握这两种技术,能帮助开发者构建更高效、更简洁的应用程序。
60 0