Retroceder   Foros del Web > Programación para sitios web > .NET > web forms

Respuesta
 
Herramientas Desplegado
Antiguo 24-sep-2006, 05:05   #1 (permalink)
oirasor ha deshabilitado el karma
 
Fecha de Ingreso: junio-2004
Mensajes: 2
Molesto Problemas al confirmar eliminacion en un gridview de asp.net 2.0

Buenas, tengo una aplicacion en vb.net 2.0 el problema lo tengo en un GridView donde tengo una columna que es un boton que al presionarlo me pide si deseo eliminar el registro con una funcion javascript y si le aprieto aceptar me ejecuta el postback y controlo en el evento rowcommand si el e.commandname es "Eliminar" que es como se llama el comando del grid y entonces ejecuto la instruccion SQL del delete, si aprieto cancelar no lo ejecuta por que no me lanza el postback.

Esto funciona perfectamente siempre y cuando el tipo del boton sea Link si el boton es image siempre me ejecuta el postback aunque le de a cancelar y claro me elimina el registro.

Alguna idea?

Os paso el codigo para que le pegueis un vistazo o por si le sirve a alguien.

Saludos y gracias anticipadas.

Funcion JavaScript
<script language="javascript" type="text/javascript">
function ConfirmDel()
{
return confirm('¿Esta seguro que desea eliminar este Registro?');
}
</script>

Aqui asigno al boton del grid la funcion Java
Protected Sub Grid_RowDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewRowEventArgs) Handles Grid.RowDataBound
Try
If e.Row.RowType <> ListItemType.Header And e.Row.RowType <> ListItemType.Footer Then
e.Row.Cells(4).Attributes.Add("onClick", "javascript:return ConfirmDel();")
End If
Catch ex As Exception

End Try
End Sub

Aqui Controlo el nombre del comando y ejecuto la sentencia
Protected Sub Grid_RowCommand(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewCommandEventArgs ) Handles Grid.RowCommand
On Error Resume Next
Dim index As Integer = Convert.ToInt32(e.CommandArgument)
Dim row As GridViewRow = Grid.Rows(index)
Dim cn As New ADODB.Connection, TransaccionActiva As Boolean

Select Case e.CommandName
Case "Modificar"
'OTRO COMANDO QUE NO VIENE A CUENTO


Case "Eliminar"
On Error GoTo ControlError
cn.ConnectionString = ConexionAdoDB()
cn.Open()
TransaccionActiva = True
cn.BeginTrans()
cn.Execute("Delete Tabla1 WHERE Id=" & Server.HtmlDecode(row.Cells(0).Text))
cn.Execute("Delete Tabla2 WHERE Id=" & Server.HtmlDecode(row.Cells(0).Text))
If TransaccionActiva = True Then
cn.CommitTrans()
TransaccionActiva = False
End If
cn.Close()
cn = Nothing
On Error Resume Next
Cargar_Grid()
End Select
Exit Sub

ControlError:
If transaccionactiva = True Then
cn.RollbackTrans()
TransaccionActiva = False
Me.lb_Comentario.text = Err.Description
End If
End Sub
oirasor está desconectado   Responder Citando
Antiguo 26-sep-2006, 09:46   #2 (permalink)
Gelipon no se puede cailificar en este momento
 
Fecha de Ingreso: agosto-2006
Mensajes: 43
Enviar un mensaje por MSN a Gelipon
Una Recomendacion

Que tal

La verdad mas que una solución a tu problema es una racomendación, ultimamente los mensajes de Alerta para confirmacion o notificacion estan un poco descontinuados, Porque no utilizas una vista, la cual al pulsar tu imagebutton se active y de una forma mas presentable y sin salir del contexto de tu pagina pregunte si quieres o no eliminar.

El unico problema que tendrías esque saldrías de tu grid, pero eso se resuelve muy facil:

case "DeleteRecord":
this.ViewState["IdToDelete"]=e.CommandArgument.Tostring();
Multiview1.SetActiveView(viewDelete);
break;

se supone que en tu view viewDelete debes tener 2 Buttons, Accept y Cancel

en el evento del button Accept se ejecutaría la baja de tu registro,por ejemplo record.Id=this.ViewState["IdToDelete"]; y ya ese Id lo utilizas para identificar a tu registro.

Eliminas y luego vuelve a recargar tu grid mediante una funcion que te treiga nuevamente los registros de la Bd, si tienes dudas please contactame
Gelipon está desconectado   Responder Citando
Antiguo 02-nov-2006, 10:57   #3 (permalink)
axpicasso ha deshabilitado el karma
 
Fecha de Ingreso: octubre-2006
Mensajes: 47
Enviar un mensaje por MSN a axpicasso Enviar un mensaje por Skype™ a axpicasso
Cool problemita

Hola, para mi lo mas recomendable seria usar el evento RowDeleting y asi es mejor y luego en el template de tipo image o lo que sea colocar lo siguiente

<asp:ImageButton runat="server" ID="nombre" ImageUrl="ruta"
OnClientClick="return eliminar()" CommandName="delete"/>

asi te recomiendo que lo hagas y seria mucho mejor.

Cualquier consulta.

ypicasso@quimicasuiza.com
axpicasso está desconectado   Responder Citando
Antiguo 19-abr-2008, 15:34   #4 (permalink)
JOSEPH_18 ha deshabilitado el karma
 
Fecha de Ingreso: julio-2006
Mensajes: 2
Re: problemita

Cita:
Iniciado por axpicasso Ver Mensaje
Hola, para mi lo mas recomendable seria usar el evento RowDeleting y asi es mejor y luego en el template de tipo image o lo que sea colocar lo siguiente

<asp:ImageButton runat="server" ID="nombre" ImageUrl="ruta"
OnClientClick="return eliminar()" CommandName="delete"/>

asi te recomiendo que lo hagas y seria mucho mejor.

Cualquier consulta.

ypicasso@quimicasuiza.com

Yo estoy utilizando Este Codigo :
<asp:ImageButton runat="server" ID="btELi" ImageUrl="../../delete.gif"
OnClientClick="return confirm('Seguro que Elimira los Datos')"
CommandName="Delete"/>
...
pero tengo un problema cuando lo corro el proyecto web, no me realiza la accion
del commandName solo refresca la pagina y quisiera saber cual podria ser el problema
por el cual no realiza la accion requerida.
Tengo otros proyecto en el cual no he tenido problema para realizar esta accion por o cual me parece raro...
JOSEPH_18 está desconectado   Responder Citando
Respuesta
No hay votos aún.


Herramientas
Desplegado

Normas de Publicación
No puedes crear nuevos temas
No puedes responder temas
No puedes subir archivos adjuntos
No puedes editar tus mensajes

BB code is Activado
Caritas están Activado
[IMG] está Activado
Código HTML está Desactivado


La Zona horaria es GMT -6. Ahora son las 22:57.


Message Board Statistics

LinkBacks Enabled by vBSEO 3.1.0

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93