WebForm的Grid页面页脚DropDownList事件[通俗易懂]

WebForm的Grid页面页脚DropDownList事件[通俗易懂]帖子http://community.csdn.net/Expert/topic/3506/3506615.xml?temp=.5394251中,提到了一个很有意思的问题。【我的datagrid的页脚有一个dropdownload控件,如果是一个BUTTON按钮的话,可以在datagrid的DG_Card_ItemCommand事件里来响应BUTTON按钮的事件,e.CommandName==

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

帖子
http://community.csdn.net/Expert/topic/3506/3506615.xml?temp=.5394251
中,提到了一个很有意思的问题。

【我的datagrid的页脚有一个dropdownload控件,如果是一个BUTTON按钮的话,可以在datagrid的
DG_Card_ItemCommand事件里来响应BUTTON按钮的事件,e.CommandName==”IButton_Name”得到

而我现在是一个dropdownload控件,当它选定一条记录的时候,怎么触发他的事件啊】

 

之前我也曾经看到过类似的问题,想当然的认为加上一个事件不就可以了吗
但是发现
在模板列,或者页眉页脚里面的DropDownList
激发不了Grid的ItemCommand事件
根本捕获不了

这算是一个大大的误区吧,没有任何验证的情况下,我居然认为,Grid里面的其他控件,只能通过激活
Grid的Itemcommand的事件来进行自己的事件操作。浮浅的很,-_-#。

于是就想好好的看看这个问题的到底怎么个意思。

参考了一些资料(包括Sunmast这个小 样 儿的blog),另外和戏子这个JR讨论了一下,终于有点明白了。

转载Sunmast的blog

By icyer(我们的大斑竹) from CSDN

首先来看看这两个事件
ItemDataBound,ItemCreated的发生时间

ItemDataBound嘛,只要执行了DataBind方法,就会马上激发这个事件。
ItemCreated呢,如果页面是第一次访问(Page.IsPostBack = false),那在第一次执行DataBind的时候,会先激发ItemCreated事件,也就是说,执行了DataBind后,首先会用ItemCreated来建立Header行,然后用ItemDataBound来绑定Header行,再用ItemCreated来建立第一行,再调用ItemDataBound来绑定第一行,也就是说ItemCreated和ItemDataBound是交替执行的。
页面返回时,也会执行ItemCreated事件,在Page_Load之前,但是这时候就不会再执行ItemDataBound事件了。

 

我们写程序的时候,一般都会有这个
Page_Load
if(!Page.IsPostBack)
{

   DataGrid1.DataSouce = ……….;
   DataGrid1.DataBind();
}

所以,在页面第一次加载的时候,我们是执行了这个ItemDataBound事件的。
但是当页面回发的时候,这个ItemDataBound事件就不再执行了。
众所周知,ViewState不会记住控件的事件,只会记住一些属性。
事件的恢复是根据InitializeComponent()这个方法来的。

所以,如果把DropDownList的事件注册,放到ItemDataBound方法里面,页面一个PostBack,事件马上丢失。
但是,如果把DropDownList的事件注册,放到ItemCreated方法里面,即使页面PostBack,事件也不会丢失,
因为Page_Load之前,重新调用了这个ItemCreated方法,这个方法是不受IsPostBack的限制的。

至此,这个问题就很清楚了。

但是,由于每次页面PostBack,都要执行ItemCreated方法,那么肯定会对效率有所影响。所以,我们能不能给出另外一种解决方法呢。戏子这个JR就提出,可以在编辑期间,就给这个DropDownList注册事件。
当然,在Grid模板列里面,点击这个DropDownList没有事件的那个闪电符号可以选择,但是我们可以改他的HTML

<asp:DropDownList id=”DropDownList2″ runat=”server” OnSelectedIndexChange=”ddl_SelectedIndexChanged”></asp:DropDownList>

这样,我们就不用动态的给这个DropDonwList注册事件了
我们仅仅需要在ItemDataBound方法里面来绑定它的数据就可以了
ps:不要忘了把ddl_SelectedIndexChanged这个方法设置为protected

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/194843.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python加入中小学课程_浙江中小学信息技术科9月换新教材,课程新增Python、PPT、H5………

    python加入中小学课程_浙江中小学信息技术科9月换新教材,课程新增Python、PPT、H5………今年9月新学期,浙江省三到九年级的信息技术课将替换新教材。与老教材相比,新版教材更接地气,以后小学生就要学会做PPT、H5,开始接触算法、大数据等。据悉,这次教材的修订,是自2017年教育部发布高中信息技术新课标后,浙江省教研室组织省内教研员、骨干教师精心修撰的成果。近段时间,浙江省教研室组织小学和初中信息技术课老师,进行三到九年级新修订教材的培训。记者翻阅新教材大纲发现,从小学三年级一直到九…

    2022年5月16日
    55
  • linux 渗透工具_适用于Linux的十大最佳渗透测试工具[通俗易懂]

    linux 渗透工具_适用于Linux的十大最佳渗透测试工具[通俗易懂]linux渗透工具ThisarticlecoverssomeofthebestpenetrationtestingtoolsforLinuxCybersecurityisabigconcernforbothsmallandbigorganizations.Inanagewheremoreandmorebusinessesaremov…

    2022年8月12日
    5
  • USB OTG简单介绍

    USB OTG简单介绍

    2021年12月4日
    39
  • 八皇后问题递归算法思想_迷宫在数据结构中的地位

    八皇后问题递归算法思想_迷宫在数据结构中的地位一、迷宫回溯问题1.问题一个7*8的数组模拟迷宫,障碍用1表示,通路使用0表示,给定起点(1,1)和终点(6,5),要求给出起点到终点的通路2.解题思路首先,我们需要给程序一个寻向的基本策略,

    2022年8月16日
    5
  • 20款优秀的免费代码编辑器

    20款优秀的免费代码编辑器Atom.io(Win7、Win8、OSX10.8、Linux)免费GitHub开发的文本编辑器Atom发布了0.177.0版,其中一个引入注目的变化是从Node.js切换到了io.js。io.js是Node.js的分支,Node.js社区发生分裂后由核心开发者在2014年12月创建的,已经发布了v1.1版,目前开发非常活跃。Atom是切换到io.js的一个重量级项目。At

    2022年6月15日
    70
  • 汇编语言—移位指令

    汇编语言—移位指令移位指令是一组经常使用的指令,包括:算数移位、逻辑移位、双精度移位、循环移位、带进位的循环移位;移位指令都有一个指定需要移动的二进制位数的操作数,该操作数可以是立即数,也可以是CL的值;在8086中,该操作数只能是1,但是在其后的CPU中,该立即数可以是定义域[1,31]之内的数;一、算数移位指令:算数移位指令分为:算数左移SAL(ShiftAlgebraicLeft)和算数右移S

    2022年5月29日
    35

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号