首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >网格视图中的ASP.NET C#代码按钮

网格视图中的ASP.NET C#代码按钮
EN

Stack Overflow用户
提问于 2011-04-06 17:26:14
回答 4查看 16.2K关注 0票数 2

您好,我有一个GridView (GridView1),我添加了一个列并插入了一个按钮:

代码语言:javascript
代码运行次数:0
运行
复制
<asp:GridView ID="GridView1" runat="server" AllowPaging="True" 
            AutoGenerateColumns="False" DataSourceID="ObjectDataSource2" 
            onselectedindexchanged="GridView1_SelectedIndexChanged" Width="798px">
            <Columns>
                .....
                <asp:ButtonField ButtonType="Button" CommandName="cmdFlag" Text="Flag" />
            </Columns>
        </asp:GridView>

基本上,在单击按钮时,我想运行SQL Update,但似乎不能单击按钮进入C#并添加查询。我可以获取页面的C#,但不确定要为该方法编写什么。

下面是C#代码:

代码语言:javascript
代码运行次数:0
运行
复制
 void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
    {
        if (e.CommandName == "cmdFlag")
        {
        con.Open();

        cmd = new SqlCommand("UPDATE Comments SET Flagged = '" + "Yes" + "'", con); 

        cmd.ExecuteNonQuery();


        }

    }

不过它什么也没做。基本上,我需要它来查看行,如果标记的按钮被单击,则将标记下的注释更新为"Yes“。

EN

回答 4

Stack Overflow用户

发布于 2011-04-06 17:30:18

你不会得到一个直接的事件。您需要在RowCommand事件上编写代码。

代码语言:javascript
代码运行次数:0
运行
复制
void GridView1_RowCommand(Object sender, GridViewCommandEventArgs e)
{
    if(e.CommandName=="cmdFlag")
        {
        //Write code update database
    }
}

此外,您还需要修改GridView控件。像这样添加事件。

代码语言:javascript
代码运行次数:0
运行
复制
onrowcommand="GridView1_RowCommand"

你可以在here上获得更多信息

票数 2
EN

Stack Overflow用户

发布于 2011-04-06 18:00:04

您忘记了在Gridview上添加OnRowCommand="GridView1_RowCommand",这就是它没有触发RowCommand事件的原因。

代码语言:javascript
代码运行次数:0
运行
复制
<asp:GridView ID="GridView1" runat="server" OnRowCommand="GridView1_RowCommand" AllowPaging="True" 
        AutoGenerateColumns="False" DataSourceID="ObjectDataSource2" 
        onselectedindexchanged="GridView1_SelectedIndexChanged" Width="798px">
票数 0
EN

Stack Overflow用户

发布于 2011-04-06 18:08:57

通过执行以下操作在代码隐藏文件中注册事件处理程序

代码语言:javascript
代码运行次数:0
运行
复制
GridView1.RowCommand += new GridViewCommandEventHandler(GridView1_RowCommand);

并将此添加到您的aspx页面中

代码语言:javascript
代码运行次数:0
运行
复制
OnRowCommand="GridView1_RowCommand"
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5564165

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档