2010-01-19 89 views
2

我有一个Asp.net GridView(使用数据绑定填充)。 我的一列是一个ButtonField(显然带有他自己的CommandName)。在RowDataBound中设置OnClientClick后事件不会触发

GridView_RowCommand作品完美,但如果我添加一个GridView_RowDataBound(其中我只需添加一个JavaScript确认)GridView_RowCommand事件不会在回发解雇。

可能是什么问题/解决方案?

添加代码,以便更好地理解:

.aspx的代码:

<asp:GridView ID="GridView1" runat="server" 
    OnRowCommand="GridView1_RowCommand" 
    onrowdatabound="GridView1_RowDataBound"> 
    <Columns> 
     <asp:BoundField DataField="MyField1" HeaderText="MyField1" /> 
     <asp:BoundField DataField="MyField2" HeaderText="MyField2" /> 
     <asp:ButtonField Text="MyAction" ButtonType="Image" ImageUrl="myaction.gif" CommandName="myaction" /> 
    </Columns> 
</asp:GridView> 

C#代码:

protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e) 
{ 
    if (e.Row.RowType == DataControlRowType.DataRow) 
    { 
     (e.Row.Cells[e.Row.Cells.Count - 1].Controls[0] as ImageButton).OnClientClick = "javascript:return confirm (\"Do action?\");"; 
    } 
} 

protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e) 
{ 
    if (e.CommandName == "myaction") 
    { 
     DoMyAction(); 
    } 
} 

编辑:

我忘了告诉我的GridView的是内部的ajax TabContainer(AjaxControlToolkit)

回答

5

这是针对图像按钮通常发出:

<input type="image" src="myaction.gif" alt="MyAction" onclick="javascript:__doPostBack('GridView1','myaction$1')" style="border-width:0px;" /> 

当你在你设置的OnClientClick代码隐藏,它会在前面加上你的代码,但仍增加了__doPostBack函数调用,导致下面的HTML :

<input type="image" src="myaction.gif" alt="MyAction" onclick="javascript:return confirm('Do action?');javascript:__doPostBack('GridView1','myaction$1')" style="border-width:0px;" /> 

的onclick事件处理程序将返回它得到一个机会做正确的回发(它只是提交表单)前。

这样做:

(e.Row.Cells[e.Row.Cells.Count - 1].Controls[0] as ImageButton).OnClientClick = "if (!confirm('Do action?')) { return false; }"; 

应该允许客户端点击事件运行__doPostBack功能,提高RowCommand事件服务器端,当用户点击OK预期。 (作为一个侧面说明,这是ASP.NET WebForms的一个缺点的很好的例子 - 有很多html被生成,你只是无法控制ASP.NET MVC FTW!)

+0

它的工作!谢谢! 我仍然想知道为什么“javascript:return confirm(\”Do action?\“);”不同于“if(!confirm('Do action?')){return false;}” 和btw你是对的:ASP.NET MVC FTW! – p4bl0 2010-01-20 10:35:36

+1

我试着回答自己..如果点击'否',但工作版本返回false,但如果点击“是”,则返回true。 – p4bl0 2010-01-20 10:43:10

+1

你已经得到它:)很高兴我能帮上忙。 – 2010-01-20 12:01:35

0

乍一看这似乎很好。你有没有尝试在TabContainer之外运行你的代码?

它可能会让你朝正确的方向发展。