Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Conexión con bases de datos

 
 
Herramientas Buscar en Tema Desplegado
  #2  
Antiguo 11-04-2015
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 38
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Cita:
Empezado por alexglez1255 Ver Mensaje
Hola jovenes tengo una pregunta,...
Se agrace...

Es inevitable que el uso del método Clear dispare el evento OnChange ya que el contenido del TEdit cambia. Y si esto lo haces dentro del evento OnChange....

Una forma de que funcione ( aunque me desagrada en absoluto ) es desasignar el evento antes de la llamada al método Clear y reasignarlo luego:
Código Delphi [-]
procedure Taltadecontratos.edtBuscarCteChange(Sender: TObject);
var
  tn : TNotifyEvent;
  tmp: Integer;
begin
  width logicanegocio do
  begin
    case cmbBusqCte.ItemIndex of
      0: begin
           if not TryStrToInt(edtBuscarCte.Text, tmp) then
           try
             ShowMessage('En el campo de Codigo solo puede escribir numeros');
             tn := edtBuscarCte.OnChange;  // guardar 
             edtBuscarCte.OnChange:= nil;  // desasignar
             edtBuscarCte.Clear;           // borrar
             Exit;
           finally
             edtBuscarCte.OnChange := tn;  // reasignar
           end;
           CDSclieCOD.Locate( 'CUSTNO', edtBuscarCte.Text,[loPartialKey] );
         end;
      1: begin
           DBGrid1.Visible := True;
           CDSclieCOD.Locate( 'COMPANY', edtBuscarCte.Text,[loPartialKey] );
           CDSclieCOD.Filtered := False;
           CDSclieCOD.Filter   := Format( 'COMPANY LIKE %s ', [ QuotedStr(edtBuscarCte.Text + '%' ) ] );
           CDSclieCOD.Filtered := True;
         end;
    end;
  end;
end;

Lo que yo haría es avisar del error y dejar que el usuario lo corrija:
Código Delphi [-]
procedure Taltadecontratos.edtBuscarCteChange(Sender: TObject);
var
  tmp: Integer;
begin
  width logicanegocio do
  begin
    case cmbBusqCte.ItemIndex of
      0: begin
           if not TryStrToInt(edtBuscarCte.Text, tmp) then
           begin
             ShowMessage('En el campo de Codigo solo puede escribir numeros');
             edtBuscarCte.SetFocus;
             Exit;
           end;
           CDSclieCOD.Locate( 'COD_CLIENTE', edtBuscarCte.Text,[loPartialKey] );
         end;
      1: begin
           DBGrid1.Visible := True;
           CDSclieCOD.Locate( 'CLIENTE', edtBuscarCte.Text,[loPartialKey] );
           CDSclieCOD.Filtered := False;
           CDSclieCOD.Filter   := Format( 'CLIENTE LIKE %s ', [ QuotedStr(edtBuscarCte.Text + '%' ) ] );
           CDSclieCOD.Filtered := True;
         end;
    end;
  end;
end;
Por otro lado, el primer código es poco amable con el usuario. Imagina que lleva ingresado: 0123456789a.
¿ Por que borrarle todo el contenido si solo tiene un caracter erroneo ?

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
 


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Datetimepicker.clear Osorio OOP 5 27-07-2017 17:13:04
Leer parámetros que manda otra aplicación NPIdea API de Windows 2 14-09-2010 11:20:22
Error al compilar proyecto que manda mail JADE_TYLER OOP 2 20-11-2009 17:51:05
simular en un DBLookupcombobox el efecto de un DBedit.clear el_barto Varios 4 11-08-2007 01:57:20
QReport me manda a imprimir 20,000 hojas El_Raso Impresión 0 23-03-2007 01:41:49


La franja horaria es GMT +2. Ahora son las 13:05:05.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi