zoukankan      html  css  js  c++  java
  • 刚刚发现的一个小问题的解决办法(datalist绑定和itemcommand)

    我的datalist数据绑定是通过在itemtemplate加上若干label然后在前台html利用类似如下代码(在label的text属性填写

    <%# DataBinder.Eval(Container.DataItem,"id"%>

    效果一样)<%# DataBinder.Eval(Container.DataItem,"id") %>来绑定数据  

    <asp:LinkButton id="btnFile" runat="server" CommandName="Select">
    <%# DataBinder.Eval(Container.DataItem,"name"%>
    </asp:LinkButton>

    <%# DataBinder.Eval(Container.DataItem,"name") %>但是最后发现如果lable也这样绑定的话,那么在itemcommand事件通过下面的代码将会得不到拉嗲拉里面的值

        Label mypid1 = (Label)e.Item.FindControl("lblID");
                            
    string id1 = mypid1.Text;
                            Label mytype1 
    = (Label)e.Item.FindControl("lblType");
                            
    string ntype1 = mytype1.Text;

    后来经过csdn提问知道如果换成如下写法

    <asp:Label id="lblID" runat="server" Width="0px" Height="0px" Text='<%# DataBinder.Eval(Container.DataItem,"id") %>'>
    </asp:Label>

    就能在后台的itemcommand事件里面取到值了,但是别人也没怎么说清楚原因,只是说如果是前面一种写法的话,那么仅仅只是有个显示文字将不写入__viewstate,所以在itemcommand里面是得不到这个值。
    希望知道的哥们能给我讲明,不胜感激
    <%# DataBinder.Eval(Container.DataItem,"name") %><%# DataBinder.Eval(Container.DataItem,"name") %><%# DataBinder.Eval(Container.DataItem,"name") %>

  • 相关阅读:
    0008_Python变量
    shiro Filter过滤器管理197
    oracle 将一个数据库(A)的表导入到另一个数据库197
    top命令使用197
    SpringBoot下载Excel文件,解决文件损坏问题197
    java元注解197
    Content-Type
    centos7 下修改网络配置
    mint 20 install NVIDIA driver for 3080 via run
    使用numpy rot90操作image后,opencv cv2.rectangle 报错
  • 原文地址:https://www.cnblogs.com/ocean2000/p/459240.html
Copyright © 2011-2022 走看看