【更正】“给自定义控件(Web Control)添加事件的几种方法”有一个不太准确的地方。
时间:2022-04-29
本文章向大家介绍【更正】“给自定义控件(Web Control)添加事件的几种方法”有一个不太准确的地方。,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
上一篇写了一下如何在自定义控件里面添加事件,由简单的开始,一步一步实现了几种添加事件的方式,由于当时只给自定义控件添加了一种外部事件,测试的时候没有什么问题,但是后来在写分页控件的时候,我给分页控件加了两种外部事件,然后测试的时候就出现了一个问题,本来只想调用外部的一种事件,结果外部的两种事件都被调用了。分析了一下,
就是这个地方写错了,不能用 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
- 想打造一个神经网络,自动给黑白照片上色?这儿有一份超详细教程
- WP_Widget_PostViews has a deprecated constructor 报错解决
- 详解Linux系统的CPU负载均值
- Linux服务器的进程查看命令详解
- 另类SEO分享:利用JS封装iframe躲过搜索引擎的抓取
- Linux :MAC 地址克隆方法
- 解决WordPress修改数据库表前缀后无法登陆的问题
- 解决启用WP-Super-Cache后出现的几个问题
- Shell下制作自解压安装包,实现脚本的简单加密
- WordPress(Twenty Ten主题)文章副标题修改教程
- ipvsadm启动报错解决办法,另附ipvsadm详细参数
- Linux:mv 命令的10个实用例子
- Linux优化方法收集与整理
- 常用MySQL语句搜集整理
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法