如何基于Listview ItemDataBound值显示面板控件

时间:2014-04-17 15:54:23

标签: vb.net listview asp.net-4.0 web-controls

使用asp.net 4.0。我有一个带有列表视图的页面。我试图在listview itemtemplate中根据当前ItemBound值显示某个预定义的Panel,但不在itemBound事件中显示....

例如,如果dataItem.Item(“DataGapDesc”)值等于“A”,则显示Panel pnlPanelA,它将具有2个文本框。如果dataItem.Item(“DataGapDesc”)值等于“B”,则显示Panel pnlPanelB,它将有3个文本框和一个复选框,依此类推。

这是我在aspx中的当前列表视图:

     <asp:ListView ID="EmployeesGroupedByDataField" runat="server" DataSourceID="sqlDataGapsForSelectedemployees" OnItemBound="employeesGroupedByDataField_ItemDataBound">
                <LayoutTemplate>
                    <table id="Table1" runat="server" class="table1">
                        <tr id="Tr1" runat="server">
                            <td id="Td1" runat="server">
                                <table ID="itemPlaceholderContainer" runat="server" >
                                    <tr id="Tr2" runat="server">
                                        <th id="Th1" runat="server" style="text-align:left"><u>
                                            employee</u></th>
                                        <th id="Th2" runat="server" style="width:5%;text-align:center"><u>
                                            # Items Missing</u></th>
                                        <th id="Th3" runat="server"><u>
                                            employee DOB</u></th>
                                        <th id="Th4" runat="server"><u>
                                            Primary Physican</u></th>
                                        <th id="Th6" runat="server" style="width:10%;text-align:center;border-right: thin solid #000000"><u>
                                            Missing Data Item</u></th>
                                        <th id="Th5" runat="server" style="text-align: center;"><u>
                                            Last Known Visit/Service</u></th>                                
                                        <th id="Th7" runat="server" style="text-align: center;"><u>
                                            Data Entry</u></th>      
                                    </tr>
                                    <tr ID="itemPlaceholder" runat="server">
                                    </tr>
                                </table>
                            </td>
                        </tr>
                        <tr id="Tr3" runat="server">
                            <td id="Td2" runat="server" style="">
                            </td>
                        </tr>
                    </table>
                </LayoutTemplate>
                <ItemTemplate>
                    <%# AddGroupingRowIfemployeeHasChanged()%>               
                            <td style="text-align: right;border-right: thin solid #000000"><%# Eval("DataGapDesc")%>&nbsp</td>
                            <td style="text-align: left;">
                                <%#Eval("ServiceDate")%> 
                                &nbsp-&nbsp
                                <%# Eval("PlaceOfService")%>
                            </td>  
                            <td>
                                <%# DisplaySpecificPanel()%>                                   
                            </td>                                                                                                                                                        
                        </tr>
                </ItemTemplate>
            </asp:ListView>

我调用函数DisplaySpecificPanel(),这是我“试图”执行此行为的地方。 VB中的那个函数:

Public Function DisplaySpecificPanel()As String

    Dim currentEmployeeNameValue As String = Trim(Eval("Employee").ToString().Substring(0, (Eval("Employee").ToString.Length) - 10).ToString())

    If currentEmployeeNameValue = "DOE, JOHN" Then
        'Panel1.Visible = True
        Return String.Format("<asp:Button ID=""Button1"" runat=""server"" Text=""Button"" />")
    Else
        Return String.Format("<asp:TextBox ID=""TextBox1"" runat=""server""></asp:TextBox>")

    End If

结束功能

现在,我只是通过添加基于值但更长期的文本框或按钮来尝试此功能,我希望添加面板... 好吧,我的函数被正确调用,但控件没有放在渲染的列表视图上。

有什么想法吗?我正在谈论这个吗?非常感谢......

1 个答案:

答案 0 :(得分:0)

从其他来源找到此信息。有道理,但我并不完全熟悉aspx页面的生命周期或行为。

  

您将无法使用字符串呈现服务器端控件   控制的表示。这种方法适用于纯HTML   控制。但是,服务器端控件需要经过渲染   只设置text的属性时不会调用的机制   一个控件。更好的替代方案是只保留一个面板   项目模板并在itemdatabound中动态添加控件   基于条件的事件。然后,您可以检查是否有某些条件   单击true,然后相应地添加文本框或按钮。如果有的话   许多控件,您也可以使用UserControls。但是,动态控制   不会在页面回发中保留,您需要添加   他们回来时使用相同的ID。如果你不想处理这一切   创建机制,你可以保留两个独立的面板和   根据某些条件更新可见性。

Listview中的

<td>                                                                       
    <asp:Panel runat="server" ID="pnlOne" Visible='<%# CanShowFirstPanel()%>'>
        <asp:Button ID="Button1" runat="server" Text="Button" />
    </asp:Panel>
    <asp:Panel runat="server" ID="pnlTwo" Visible='<%# CanShowSecondPanel()%>'>
        <asp:TextBox runat="server" ID="TextBox1" />
    </asp:Panel>
</td>

代码隐藏:

Public Function CanShowFirstPanel() As Boolean
       'condition to check 
       Return True
   End Function
   Public Function CanShowSecondPanel() As Boolean
       'condition to check 
       Return False
   End Function