zoukankan      html  css  js  c++  java
  • 关于ListView下隐藏控件的解决方案

    今天,给一个北京一个专科生做毕业设计,做了好几天,应该这两天就快要完工了。正以为自己很得意的时候,今天碰到了很尴尬的事情。就是我想实现一个功能,这个功能挺简单,就是当不是管理员用户登入的时候,那这个 删除 按钮就被隐藏掉;当是管理员用户的时候,就重新显示出来。

    这是ListView模板里的代码,贴一下,方便理解:

    方案一:

    就是想把DeleteButton 和EditButton 2个按钮隐藏
    <ItemTemplate>
                    <tr>
                        <td>
                             <asp:Button ID="DeleteButton" runat="server"    CommandName="Delete" Text="删除" />
                            <asp:Button ID="EditButton" runat="server" 
                                CommandName="Edit" Text="编辑" />
                        </td>
                        <td style="">
                            <div style=" 30px;">
                                <asp:Label ID="UserNameLabel" runat="server" Text='<%# Eval("UserName") %>' Width="30px" /></div>
                        </td>
                        <td>
                            <asp:Label ID="AgeLabel" runat="server" Text='<%# Eval("Age") %>' />
                        </td>
                        <td>
                            <asp:Label ID="IdentityCardLabel" runat="server" Text='<%# Eval("IdentityCard") %>' />
                        </td>
                        <td>
                            <asp:Label ID="LoginDateLabel" runat="server" Text='<%# Eval("LoginDate","{0:yyyy-MM-dd}") %>' />
                        </td>
                        <td>
                            <asp:Label ID="LeaveDateLabel" runat="server" Text='<%# Eval("LeaveDate","{0:yyyy-MM-dd}") %>' />
                        </td>
                        <td>
                            <asp:Label ID="PopulationLabel" runat="server" Text='<%# Eval("Population") %>' />
                        </td>
                        <td>
                            <asp:Label ID="HouseIDLabel" runat="server" Text='<%# Eval("HouseID") %>' />
                        </td>
                    </tr>
                </ItemTemplate>
    

    一开始,觉得这挺简单,就写下了下面的代码:

    protected void ListView1_ItemCreated(object sender, ListViewItemEventArgs e)
        {
    
            Button DeleteButton = (Button)ListView1.FindControl("DeleteButton");
            Button EditButton = (Button)ListView1.FindControl("EditButton");
            string username = Session["username"].ToString();
            if (username != "admin")
            {      
                    EditButton.Visible = false;
                    DeleteButton.Visible = false;
            }
       }
    

    可是,当运行的时候,就开始报错说,将对象引用设置到对象的实例。就是说没有找到这个控件,我就很奇怪了,觉得很没有道理。按理ItemCreated是在初始化行之后,然后进行找控件,应该没问题。

    这个问题,想了很久,没有结果,然后就和我一个同学(他技术不错)开始讨论,刚开始他说是,就是说当运行页面的时候,在

    去查看源码带的时候,发现DeleteButton这个控件的ID 变样了,变成了ListView1_ctrl0_DeleteButton这样子。对于这个问题,

    我一直到现在还没有想通,不知道MS怎么会搞这个出来?服务器控件不是好好的渲染到页面了,怎么变ID了呢?没理由。呵呵~~

    然后,我同学经过调试后,给出了一个解决方案是:

     

    protected void ListView1_ItemCreated(object sender, ListViewItemEventArgs e)
        {
    
            Button DeleteButton = (Button)ListView1.FindControl("DeleteButton");
            Button EditButton = (Button)ListView1.FindControl("EditButton");
            string username = Session["username"].ToString();
            if (username != "admin")
            {
                if (DeleteButton != null && EditButton != null)
                {
                    EditButton.Visible = false;
                    DeleteButton.Visible = false;
                }
            }
    }
    

    这样子就可以了。就是多加了一句:if (DeleteButton != null && EditButton != null)的判断。

    方案二:

    很有才的是,我宿舍的一位河北的同学也给出了一种解决方案,不过这种写法看起来有点不可思议,呵呵,一起看看

    吧!

    <asp:Button ID="DeleteButton" runat="server" Visible='<%#Session["username"]=="admin"?true:false %>'
    

    就是这样子,也可以把控件给隐藏。因为session是全局变量,所以可以在页面中取到这个值。

  • 相关阅读:
    算法生成卐和卍字图
    分形之可编辑折线
    算法生成太极八卦图
    通过算法生成一幅太极图
    使用异或运算对数据及文件进行加密处理,附软件及源码
    C语言中将0到1000的浮点数用强制指针类型转换的方式生成一幅图像
    算法之美---100幅由程序生成的图像,总有一幅让你感到惊艳[下]
    【python基础学习】基础重点难点知识汇总
    【深入学习linux】在linux系统下怎么编写c语言程序并运行
    【深入学习linux】CentOS 7 最小化安装后程序必须安装的组件
  • 原文地址:https://www.cnblogs.com/damonlan/p/2008791.html
Copyright © 2011-2022 走看看