如何隐藏自动生成的“删除和编辑”按钮 在网格视图中 asp.net 用户的网格视图中
本文关键字:网格 视图 按钮 用户 删除和编辑 net asp 隐藏 何隐藏 自动生成 删除 | 更新日期: 2023-09-27 18:30:52
我想隐藏客户角色中的删除编辑按钮,但管理员可以看到它们。我的网格视图已设置自动生成列 = true。
这是我所做的:
<asp:GridView ID="grdview" OnRowCreated="grdview_RowCreated" OnRowDataBound="grdview_RowDataBound" CssClass="table table-hover table-responsive" runat="server" AutoGenerateColumns="False" DataKeyNames="id" DataSourceID="EntityDataSource1">
<Columns>
<asp:BoundField DataField="id" HeaderText="id" ReadOnly="True" SortExpression="id" Visible="False" />
<asp:BoundField DataField="InvoiceNo" HeaderText="InvoiceNo" SortExpression="InvoiceNo" NullDisplayText="Null" >
<ControlStyle CssClass="form-control" />
</asp:BoundField>
<asp:TemplateField HeaderText="InvoiceDate" SortExpression="InvoiceDate">
<EditItemTemplate >
<div class=" input-group">
<asp:TextBox ID="txtdate2" runat="server" CssClass="form-control" Text='<%# Bind("InvoiceDate") %>'></asp:TextBox>
<span class="input-group-addon">
<a class=" glyphicon glyphicon-calendar" id="cal2"></a>
<asp:CalendarExtender ID="CalendarExtender2" PopupButtonID="cal2" Format="dd/MM/yyyy" TargetControlID="txtdate2" runat="server"></asp:CalendarExtender>
</span>
</div>
</EditItemTemplate>
<ItemTemplate>
<asp:Label ID="Label1" runat="server" Text='<%# Bind("InvoiceDate") %>'></asp:Label>
</ItemTemplate>
<HeaderStyle Width="200px" />
<ItemStyle Width="200px" />
</asp:TemplateField>
<asp:BoundField DataField="Amount" HeaderText="Amount" SortExpression="Amount" >
<ControlStyle CssClass="form-control" />
</asp:BoundField>
<asp:BoundField DataField="Items" HeaderText="Items" SortExpression="Items" >
<ControlStyle CssClass="form-control" />
</asp:BoundField>
<asp:BoundField DataField="category" HeaderText="Category" SortExpression="category" Visible="False" >
<ControlStyle CssClass="form-control" />
</asp:BoundField>
<asp:BoundField DataField="description" HeaderText="Description" SortExpression="description" Visible="False" />
<asp:BoundField DataField="qty" HeaderText="Qty" SortExpression="qty" >
<ControlStyle CssClass="form-control" />
</asp:BoundField>
<asp:BoundField DataField="remarks" HeaderText="Remarks" SortExpression="remarks" >
<ControlStyle CssClass="form-control" />
</asp:BoundField>
<asp:BoundField DataField="PartyId" HeaderText="PartyId" SortExpression="PartyId" Visible="False" />
<asp:TemplateField HeaderText="Action" ShowHeader="False" SortExpression="id">
<EditItemTemplate>
<asp:LinkButton ID="LinkButton1" runat="server" CausesValidation="True" CommandName="Update" Text="Update"></asp:LinkButton>
<asp:LinkButton ID="LinkButton2" runat="server" CausesValidation="False" CommandName="Cancel" Text="Cancel"></asp:LinkButton>
</EditItemTemplate>
<ItemTemplate>
<asp:LinkButton ID="LinkButton1" runat="server" CausesValidation="False" CommandName="Edit" Text="Edit"></asp:LinkButton>
<asp:LinkButton ID="LinkButton2" runat="server" CausesValidation="False" CommandName="Delete" Text="Delete"></asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
这是我尝试执行显示和隐藏列的行数据绑定事件
protected void grdview_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow) {
if (!admin())
e.Row.Cells[5].Visible = false;
}
else if (e.Row.RowType == DataControlRowType.Header) {
if(!admin())
e.Row.Cells[6].Visible = false;
}
}
您还可以按如下方式使用 Gridview 预呈现事件。
protected void grdview_RowDataBound(object sender, EventArgs e)
{
if(!admin())
{
grdview.Columns[5].Visible = true;
}
else
{
//do something
}
}