0

我有一个带有网格视图的网络表单。第一列有一个按钮“更新”和“删除”。我想要的是当我单击删除按钮时,代码会获取我第三列中的 id。

使用下面的代码我只得到“1”

if (e.CommandName == "Delete")
{
    int id = Convert.ToInt32(e.CommandArgument);
    GridViewRow row = GridView1.Rows[id];

    Add_update delete = new Add_update();
    delete.deleteVehicle(Convert.ToInt32(id));
    reload();
}
4

1 回答 1

0

使用 CommandArgument 按索引来定位 Row 并不是一个好习惯,因为例如可以通过排序来更改行顺序。


public partial class _Default : Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!Page.IsPostBack)
            {
                var dataObjects = new List<DataObject>();

                for (int i = 0; i < 100; i++)
                {
                    dataObjects.Add(new DataObject() { Index = i });
                }

                gridView1.DataSource = dataObjects;
                gridView1.DataBind();
            }
        }

        protected void gridView1_RowCommand(object sender, GridViewCommandEventArgs e)
        {
            if (e.CommandName == "Delete")
            {
                var dataObjectIndex = int.Parse((string) e.CommandArgument);
                e.Handled = true;
            }
        }
    }

    public class DataObject
    {
        public int Index { get; set; }
    }


    <asp:GridView ID="gridView1" runat="server" OnRowCommand="gridView1_RowCommand" AutoGenerateColumns="false">
        <Columns>
            <asp:BoundField DataField="Index" HeaderText="Index" />
            <asp:TemplateField>
                <ItemTemplate>
                    <asp:Button ID="btnDelete" runat="server" CommandName="Delete" CommandArgument='<%# Bind("Index") %>' />
                </ItemTemplate>
            </asp:TemplateField>
        </Columns>
    </asp:GridView>

于 2019-01-16T09:14:20.853 回答