Foros del Web » Programando para Internet » Jquery »

Autocompletar jquery varios valores

Estas en el tema de Autocompletar jquery varios valores en el foro de Jquery en Foros del Web. Hola Estoy haciendo un formulario en el que el <input type="text"> de los idiomas va con un autocompletar. El problema está en que sólo me ...
  #1 (permalink)  
Antiguo 03/06/2012, 03:54
 
Fecha de Ingreso: marzo-2009
Mensajes: 395
Antigüedad: 15 años, 8 meses
Puntos: 11
Autocompletar jquery varios valores

Hola

Estoy haciendo un formulario en el que el <input type="text"> de los idiomas va con un autocompletar.

El problema está en que sólo me funciona para el primer valor, pero una vez rellenado este, si quiero añadir otro idioma, es decir, si una persona sabe inglés y alemán, me funciona al meter in, que directamente me sale inglés, pero al meter seguido la al de alemania, no me sale nada.

Este es mi código:

Código:
<script src="../js/jquery.js" type="text/javascript"></script>	
<script type="text/javascript" src="../js/jquery-ui.js"></script>
<script>
$(document).ready(function(){

	$(function() {
	var idiomas = ["Inglés", "Francés", 
	  "Alemán", "Italiano"];

	$("#idiomas").autocomplete({
	  source: idiomas
	});
});
});
</script>

<input type="idiomas" id="idiomas">
Gracias.

Por cierto, como hacen en hotmail para que cuando meten la dirección de correo y la autocompletas, esta quede como dentro de un div?
  #2 (permalink)  
Antiguo 03/06/2012, 04:17
 
Fecha de Ingreso: marzo-2009
Mensajes: 395
Antigüedad: 15 años, 8 meses
Puntos: 11
Respuesta: Autocompletar jquery varios valores

Lo he solucionado con el siguietne código:

Código:
$(function() {

		var availableTags = [

			"Inglés",

			"Alemán",

			"Francés",

			"Italiano",

			

		];

		function split( val ) {

			return val.split( /,\s*/ );

		}

		function extractLast( term ) {

			return split( term ).pop();

		}



		$( "#idiomas" )

			

			.bind( "keydown", function( event ) {

				if ( event.keyCode === $.ui.keyCode.TAB &&

						$( this ).data( "autocomplete" ).menu.active ) {

					event.preventDefault();

				}

			})

			.autocomplete({

				minLength: 1,

				source: function( request, response ) {

					

					response( $.ui.autocomplete.filter(

						availableTags, extractLast( request.term ) ) );

				},

				focus: function() {

					

					return false;

				},

				select: function( event, ui ) {

					var terms = split( this.value );

					

					terms.pop();

					

					terms.push( ui.item.value );

					terms.push( "" );

					this.value = terms.join( ", " );

					return false;

				}

			});

	});

Etiquetas: formulario, funcion, input, js, autocompletado
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 01:08.