0

嘿,我正在使用 gridview 中的按钮,每个我想分配给特定操作的按钮都涉及从我尝试使用的 gridview 列中检索某些单元格值

 GridViewRow row = (GridViewRow (((Button)e.CommandSource).NamingContainer);

但它让我无法将“System.Web.UI.WebControls.GridView”类型的对象转换为“System.Web.UI.WebControls.Button”。

我也试过

int index = Convert.ToInt32(e.CommandArgument);
GridViewRow row = GridView1.Rows[index];

它给了我以下错误指定的参数超出了有效值的范围。参数名称:索引

请注意,当我尝试指定 ButtonField 的 commandParameters 属性时,编译器说它不是 ButtonField 的有效参数,并且我在 gridview 中有 8 列,因此它没有超出范围

或者,如果可以的话,我可以使用多个选择命令按钮如何说点击了哪个?

请帮助我,我绝望了

ASP 代码:

 <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="AcitivityId" DataSourceID="SqlDataSource1" Height="304px" Width="912px" OnRowCommand="GridView1_RowCommand">
            <Columns>
                <asp:BoundField DataField="AcitivityId" HeaderText="AcitivityId" InsertVisible="False" ReadOnly="True" SortExpression="AcitivityId" />
                <asp:BoundField DataField="ActiviityName" HeaderText="ActiviityName" SortExpression="ActiviityName" />
                <asp:BoundField DataField="ActivityLocation" HeaderText="ActivityLocation" SortExpression="ActivityLocation" />
                <asp:BoundField DataField="ActivityStartDate" HeaderText="ActivityStartDate" SortExpression="ActivityStartDate" />
                <asp:BoundField DataField="ActivityDueDate" HeaderText="ActivityDueDate" SortExpression="ActivityDueDate" />
                <asp:BoundField DataField="ActivityDescription" HeaderText="ActivityDescription" SortExpression="ActivityDescription" />
                <asp:ButtonField ButtonType="Button" CommandName="Avaliable" Text="Show avaliable buses" />
                <asp:ButtonField ButtonType="Button" CommandName="Assigned" Text="Show assigned buses "/>
            </Columns>
        </asp:GridView>
4

1 回答 1

0

我在我网站上的许多地方使用此代码从触发 GridViewRowCommand 的对象中获取行

protected void btnUpdate_Command(object sender, CommandEventArgs e)
{
    GridViewRow g = (GridViewRow)((Button)sender).NamingContainer;
    // other stuff
}

希望这可以帮助。

于 2013-04-27T04:47:53.127 回答