0

在我的中继器上,我建立了一个表格,并想为角色管理员的用户显示一个列。
我需要删除 HeaderTemplate 和 ItemTemplate 中的列。
我可以使用数据逻辑并添加一个布尔值的 db 列,但是我需要将用户角色发送给 SP。

<asp:Repeater ID="TemplatesList" runat="server">
    <HeaderTemplate>
        <table>
            <tr>
                <th>
                    #
                </th>
                <th>
                    Title
                </th>
                <th>
                    Subject
                </th>
                <th>
                    &nbsp;
                </th>
                <th>
                    &nbsp;
                </th>
            </tr>
    </HeaderTemplate>
    <ItemTemplate>
        <tr>
            <td>
                <%# Eval("ET_ID")%>
            </td>
            <td>
                <%# Eval("ET_Title")%>
            </td>
            <td>
                <%# Eval("ET_Subject")%>
            </td>
            <td>
                <a href="<%# VirtualPathUtility.ToAbsolute("~/Admin/EmailsTemplates/Delete.aspx?id="+Eval("ET_ID").ToString())%>">
                    Delete</a>
            </td>
            <td>
                <a href="<%# VirtualPathUtility.ToAbsolute("~/Admin/EmailsTemplates/Edit.aspx?id="+Eval("ET_ID").ToString())%>">
                    Edit</a>
            </td>
        </tr>
    </ItemTemplate>
    <FooterTemplate>
        </table>
    </FooterTemplate>
</asp:Repeater>
4

1 回答 1

2

如果您只想隐藏该列,则可以使用 LoginView 控件,该控件可以根据角色选择内容:

http://msdn.microsoft.com/en-us/library/system.web.ui.webcontrols.loginview.aspx

它应该在模板中工作

或者您可以使用内联脚本,如下所示:

<% if (User.IsInRole("Admin")) { %>
<td> xxx </td>
<% } %>
于 2011-03-21T09:14:53.050 回答