FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Busqueda incremental en un Edit
Hola estoy usando Delphi 7 y MySQL. Quería saber como hacer una búsqueda incremental, como la de los buscadores de Internet. Mi intención es que mientras escriba dentro de un Edit, abajo de este aparezcan las distintas opciones, luego presionar Enter y que la opción elegida pase a una grilla.
Muchas Gracias. |
#2
|
||||
|
||||
en la parte inferior de este hilo tiens muchos enlaces
|
#3
|
||||
|
||||
Hola.
Creo que vas a lograr un efecto similar a lo que buscas usando un TComboBox con su propiedad Style = csSimple:
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#4
|
|||
|
|||
Gracias ecfisa por la ayuda.
|
#5
|
|||
|
|||
Aque te refieres cuando pones VALOR ?????????
|
#6
|
|||
|
|||
Ya puede resolver, VALOR es una propiedad del combobox, otra pregunta, como puedo hacer para que al momento que encuentre un resultado y al darle click o enter se desaparezca la ventanita?????????????????
|
#7
|
||||
|
||||
Hola dekorone16.
VALOR es el nombre del parámetro que se le envia a la consulta SQL. Dentro de la consulta y para que pueda ser reconocido como parametro siempre debe ir precedido de dos puntos ( : ). Por ejemplo si tomando en cuenta el código anterior hicieramos: La consulta que se efectuaría sería: Mostrando aquellos campos que comienzan por PER y por haber usado la función UPPER también per, Per, pER, etc. Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 07-05-2012 a las 21:36:57. |
#8
|
||||
|
||||
Cita:
No entiendo bien... ¿ Donde haces el click y que es lo que deseas que desaparezca ? Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#9
|
|||
|
|||
Hy
Por ejemplo:
Si escribo la letra "J" me aparecen todos los posibles resultados con la letra "J" como JUAN,JOSE,JULIAN, ahora si selecciono JOSE se pone el nombre en el TComboBox pero sigue apareciendo la lista de los resultados. ¿Como se elimina esa lista al momento de que hayas seleccionado un registro? |
#10
|
||||
|
||||
Hola dekorone16.
Cita:
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#11
|
|||
|
|||
Hola
Creo que no me eh explicado bien, cuando hace la búsqueda los resultados vienen dentro de un rectángulo, solo quiero que al seleccionar el registro que quiero se elimine o esconda el rectángulo !!
|
#12
|
||||
|
||||
Hola.
Si deseas que ademas de eliminarse los items también se repliegue el ComboBox, sería:
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#13
|
|||
|
|||
Hola
No logro hacer que se repliegue cuando selecciono el registro que quiero, seguiré intentando, gracias !
|
#14
|
||||
|
||||
Hola.
El código que te puse hace lo que solicitaste. Es decir, al salir del ComboBox elimina los items, se repliega y deja en la propiedad Text del combo la seleccion o lo ingresado. Lo que podría no ser el evento que desees considerar para determinar que un ítem a sido seleccionado. Pero basta con ejecutar el código en el evento que prefieras para obtener el comportamiento. Como por ejemplo en OnKeyPreess cuando se presione tecla Intro. Otro punto a tener en cuenta es que usando LIKE pudiera ser que se acepte un valor que tenga una correspondencia parcial con el dato actualmente seleccionado. Si no entiendo mál lo que estas buscando, probá utilizando un TDBLookupComboBox. Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#15
|
|||
|
|||
Hola
Y el código que tienes en que evento va insertado ??????
|
#16
|
||||
|
||||
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#17
|
|||
|
|||
Hola
tengo este codigo en el evento onChange y tambien lo eh probado en el onKeyPress, es el mismo que publicaste al principio solo que no encuentro el error para que al momento de seleccionar el registro que quiero se eliminen los demas items
Código:
with TComboBox(Sender) do begin if Text > '' then begin dm.q3.Close; dm.q3.SQL.Clear; dm.q3.SQL.Add('SELECT Nombre FROM rh_empleados'); dm.q3.SQL.Add('WHERE Nombre LIKE UPPER(:Nombre)'); dm.q3.ParamByName('Nombre').AsString:= ComboBox1.Text+'%'; dm.q3.Open; while not dm.q3.Eof do begin if Items.IndexOf(dm.q3.FieldByName('Nombre').AsString) = -1 then ComboBox1.Items.Add(dm.q3.FieldByName('Nombre').AsString); dm.q3.Next; end; Height:= DropDownCount * CBOX_HEIGHT; end else begin Clear; Height:= CBOX_HEIGHT; end; end; |
#18
|
||||
|
||||
Hola dekorone16.
Como ya te comente en el mensaje #14: Cita:
Para ejemplificar voy a considerar que el usuario seleccionó un item en cualquiera de estos casos:
Como es llamado desde tres eventos, para evitar redundancia puse el código dentro de un procedimiento, pero como verás es la misma porción de código de que he estado hablando. En cualquier caso, encontrarás el valor seleccionado en la propiedad Text del TComboBox o cadena vacía si ninguno fué seleccionado. Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#19
|
|||
|
|||
Hola
Muchísimas gracias con ese procedimiento ya quedo, gracias y perdón por la insistencia !!!!
|
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
busqueda incremental | lucas05 | Varios | 15 | 23-08-2010 20:21:04 |
Busqueda incremental con ComboBox | Lenny | Varios | 2 | 18-05-2010 01:02:34 |
busqueda incremental con mysql | schaka | SQL | 2 | 09-02-2008 04:56:06 |
Consulta Busqueda Incremental | Gustavo Gowdak | SQL | 1 | 13-12-2004 09:27:08 |
busqueda incremental con ado | slat | Conexión con bases de datos | 1 | 11-07-2004 18:32:52 |
|