使列在ASP.net网格视图中可编辑

本文关键字:视图 编辑 网格 net ASP | 更新日期: 2023-09-27 18:28:31

我有一个GridView,其中一列用于字段的显示顺序,这些字段将显示在我的网站前端。与其进入编辑页面中的每一条记录并以这种方式更改顺序,不如点击一个按钮并使整个DisplayOrder(int)可编辑,从而使生活变得更轻松。如何做到这一点?

使列在ASP.net网格视图中可编辑

试试这个代码:

 <asp:ListBox ID="ListBox1" runat="server">
                <asp:ListItem>Manager1</asp:ListItem>
                <asp:ListItem>Manager2</asp:ListItem>
                <asp:ListItem>Manager3</asp:ListItem>
                <asp:ListItem>Manager4</asp:ListItem>
            </asp:ListBox>
            <asp:GridView ID="UserAllocationGrid" runat="server"
                AutoGenerateColumns="False">
            <Columns>
                <asp:BoundField DataField="Manager" HeaderText="Manager"
                    SortExpression="managers" />
                    <asp:TemplateField HeaderText="Allocation Percentage">
                    <ItemTemplate>
                        <asp:TextBox ID="TextBox1" runat="server"
                            Text= '<%# Bind("AllocationPercentage") %>' BorderStyle="None"></asp:TextBox>
                    </ItemTemplate>
                    </asp:TemplateField>
            </Columns>
            </asp:GridView>

背后的代码

     void fillGV()
        {
            DataTable UserAllocationTable = new DataTable();
            UserAllocationTable.Columns.Add("Manager");
            UserAllocationTable.Columns.Add("AllocationPercentage");
            // go through listbox1 to find selected managers = selectedManagersList 
            List<string> selectedManagersListDates = new List<string>();
            int counterR = 0;
            foreach (ListItem strItem in ListBox1.Items)
            {                     
                    //selectedManagersListDates.Add(strItem.Value); 
                    DataRow drManagerName = UserAllocationTable.NewRow();
                    UserAllocationTable.Rows.Add(drManagerName);
                    UserAllocationTable.Rows[counterR]["Manager"] = strItem.Value;
                    counterR = counterR + 1;            
            }
           // ViewState["UserAllocationTable"] = UserAllocationTable;
            UserAllocationGrid.DataSource = UserAllocationTable;
            UserAllocationGrid.DataBind(); 
        }

使用这个空白在任何情况下我做了它在邻接点击

      protected void Button1_Click(object sender, EventArgs e)
        {
            fillGV();
        }

您可以在asp命令字段中使用ShowDeleteButton="true"尝试此操作,您可以使gridview可编辑:-

<Columns>
     <asp:CommandField ShowDeleteButton="True" ShowEditButton="True" ShowSelectButton="True" />
      <asp:BoundField DataField="ID" HeaderText="ID" ReadOnly="True" SortExpression="ID" />
      <asp:BoundField DataField="Name" HeaderText="Name"    SortExpression="Name" />
   </Columns>

可能会帮助您

您可以尝试以下操作:

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" AutoGenerateEditButton = "true">
       <Columns>
            <asp:BoundField DataField="prodId" HeaderText="Product Id" SortExpression="prodId" ReadOnly = "true" />
            <asp:BoundField DataField="prodQuantity" HeaderText="Quantity" 
                                SortExpression="prodQuantity" ReadOnly = "true" />
        </Columns>
</asp:GridView>

Gridview级别设置AutoGenerateEditButton = "true"。这将使用户能够编辑行。在"数据字段"级别,使用ReadOnly = "true"防止编辑特定字段(在行中)。

希望这能有所帮助。

您可以尝试一下,它会在列中提供文本框

    <asp:Label ID="DescriptionLabel" runat="server"
        Text='<%# Eval("Description") %>'></asp:Label>
    <asp:TextBox ID="Description" runat="server"
        Text='<%# Eval("Description") %>' Width="175px"
        visible="false"></asp:TextBox>
</ItemTemplate>

这个链接有我想要的答案。如果您有自定义数据源,则必须处理GridView引发的每个编辑事件。就我而言:

Protected Sub gMaterias_RowCancelingEdit(sender As Object, e As GridViewCancelEditEventArgs) Handles gMaterias.RowCancelingEdit
    gMaterias.EditIndex = -1
    BindData()
End Sub
Protected Sub gMaterias_RowEditing(sender As Object, e As GridViewEditEventArgs) Handles gMaterias.RowEditing
    gMaterias.EditIndex = e.NewEditIndex
    BindData()
End Sub
Protected Sub gMaterias_RowUpdating(sender As Object, e As GridViewUpdateEventArgs) Handles gMaterias.RowUpdating
    lError.Visible = False
    lError.Text = ""
    Dim idMateria As Integer = e.Keys(0)
    Dim row As GridViewRow = gMaterias.Rows(e.RowIndex)
    Dim tbl As DataTable = Session("Materias")
    tbl.Rows(row.DataItemIndex)("universidad") = CType(gMaterias.Rows(e.RowIndex).Cells(5).Controls(0), TextBox).Text
    Dim calf = CType(gMaterias.Rows(e.RowIndex).Cells(6).Controls(0), TextBox).Text
    If IsNumeric(calf) Then
        tbl.Rows(row.DataItemIndex)("calificacion") = calf
    Else
        lError.Visible = True
        lError.Text = "La calificación no es válida"
    End If
    gMaterias.EditIndex = -1
    BindData()
End Sub