asp之前的Javascript:ButtonField点击

时间:2008-10-20 14:59:42

标签: asp.net javascript gridview

我在Asp.net应用程序中有一个GridView控件,其<asp:buttonField> type="image"CommandName="Delete"

有没有办法在到达OnRowDelete事件之前执行一段javascript?

我想在删除行之前进行简单的确认。

谢谢!

编辑:请注意,<asp:ButtonField>代码没有 OnClientClick属性。

5 个答案:

答案 0 :(得分:23)

我会使用TemplateField,并使用常规的asp:Button或asp:ImageButton填充ItemTemplate,具体取决于所需的内容。然后,您可以执行与拦截Delete命令时RowCommand事件要执行的逻辑相同的操作。

在其中任何一个按钮上,我将使用OnClientClick属性在此之前执行JavaScript确认对话框。

<script type="text/javascript">
   function confirmDelete()
   {
       return confirm("Are you sure you want to delete this?");
   }
</script>

...

<asp:TemplateField>
  <ItemTemplate>
     <asp:ImageButton ID="DeleteButton" runat="server"
        ImageUrl="..." AlternateText="Delete" ToolTip="Delete"
        CommandName="Delete" CommandArgument='<%# Eval("ID") %>'
        OnClientClick="return confirmDelete();" />
  </ItemTemplate>
</asp:TemplateField>

答案 1 :(得分:15)

我发现最优雅的方法是使用jQuery连接onClick事件:

<script type="text/javascript"> 
    $(".deleteLink").click(function() {
      return confirm('Are you sure you wish to delete this record?');
    });
</script>

...

<asp:ButtonField ButtonType="Link" Text="Delete"
    CommandName="Delete" ItemStyle-CssClass="deleteLink" />

请注意,我使用任意CSS类来标识链接按钮。

答案 2 :(得分:2)

GridView的{​​{1}}事件处理程序中,使用RowCreated查找命名按钮,然后添加到Attributes集合中:

FindControl

只有在confirm()为真时才会执行ASP.Net代码,即已经确定。

答案 3 :(得分:0)

所以我有一个javascript函数:

function confirmDeleteContact() {
  if (confirm("Are you sure you want to delete this contact?")) {
    document.all.answer.value="yes";
  } else {
    document.all.answer.value="no";
  }
}

我将它连接到网格项,如下所示:

Sub dgbind(ByVal sender As Object, ByVal e As DataGridItemEventArgs) Handles dgcontacts.ItemDataBound
    Select Case e.Item.ItemType
        Case ListItemType.Item, ListItemType.AlternatingItem
            CType(e.Item.Cells(9).Controls(0), System.Web.UI.WebControls.LinkButton).Attributes.Add("onclick", "javascript:confirmDeleteContact();")
    End Select
End Sub

这是一些旧的代码,所以我看到了一些我可以改变的东西,但道德是:如果所有其他方法都失败了,在行绑定期间添加javascript“onClick”。 “document.all.answer.value”是一个隐藏字段,runat=server,以便我可以在回发时读取该值。

答案 4 :(得分:-2)

如果您使用buttonfield,则更好地添加引用System.Windows.Forms ...它始终可用于所有.net框架并支持asp.net ..

如果按钮区域是您的最佳选择,这是您的选择.. 样品:

using System.Windows.Forms;

protected void BorrowItem_RowCommand(object sender, GridViewCommandEventArgs e)
{

    if (e.CommandName == "Delete")
    {

        if (System.Windows.Forms.MessageBox.Show("Do you want to delete", "Delete",MessageBoxButtons.OKCancel, MessageBoxIcon.Question, MessageBoxDefaultButton.Button1, MessageBoxOptions.ServiceNotification) != System.Windows.Forms.DialogResult.OK)
        {
            return;
         }
     }
//Continue execution...
}

//drimaster