Autor
|
Tema: Llamar dos funciones AJAX en onChange (Leído 13,110 veces)
|
KateLibby
Desconectado
Mensajes: 90
|
Tengo un formulario en el que habrá tres combos. Según lo que se elija en el primer combo se llenarán los otros dos (es decir, el segundo y el tercero son independientes el uno del otro). Para llenar el combo 2 y 3 tengo una función para cada uno, la cual llama a su archivo php correspondiente mediante AJAX. Mi problema es que no consigo llamar a las dos funciones cuando hago el onChange del <select>. Lo hago de la siguiente manera: function AjaxDias(datos, result){ divResultado = document.getElementById(result); ajax=objetoAjax(); ajax.open("GET", "ajax_dias.php?id=" + datos); ajax.onreadystatechange=function() { if (ajax.readyState==4) { divResultado.innerHTML = ajax.responseText } } ajax.send(null) } function AjaxHoras(datos, result){ divResultado = document.getElementById(result); ajax=objetoAjax(); ajax.open("GET", "ajax_horas.php?id=" + datos); ajax.onreadystatechange=function() { if (ajax.readyState==4) { divResultado.innerHTML = ajax.responseText } } ajax.send(null) } <select onChange=" AjaxDias(this.value, 'dias'); AjaxHoras(this.value, 'horas') "> Si en las funciones, en lugar del código AJAX que tengo ahora, les pongo simplemente un alert('Hola'), por poner un ejemplo, sí que me ejecuta las dos, pero con el código AJAX sólo me ejecuta una. ¿Alguna idea de cómo puedo llamar las dos funciones en onChange? Gracias.
|
|
|
En línea
|
|
|
|
adastra
Endless Learner
Ex-Staff
Desconectado
Mensajes: 885
http://thehackerway.com/
|
Vaya que raro, deberian ejecutarse ambas... que hace la función objetoAjax()? por otro lado, te salen errores de javascript en el navegador o simplemente no se ejecutan? estas seguro invocando esto: "ajax.send(null)" no te sale un error javascript?
|
|
|
En línea
|
|
|
|
KateLibby
Desconectado
Mensajes: 90
|
Os pongo la función objetoAjax() function objetoAjax(){ var xmlhttp=false; try { xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); } catch (E) { xmlhttp = false; } } if (!xmlhttp && typeof XMLHttpRequest!='undefined') {
xmlhttp = new XMLHttpRequest();
} return xmlhttp; } El navegador no me da errores (bueno, sí me da uno pero es en un .css y supongo que no tiene importancia). Simplemente es que no se ejecuta una de las funciones. Sólo se ejecuta la segunda. Y la verdad es que no estoy muy segura de lo de ajax.send(null). En realidad no lo estoy nada. He hecho muy poca cosa con AJAX y este código es copiado y pegado de uno que me funcionaba, pero aplicándole los cambios necesarios
|
|
« Última modificación: 19 Octubre 2011, 18:06 pm por KateLibby »
|
En línea
|
|
|
|
fran800m
Desconectado
Mensajes: 204
|
Hace tiempo que no toco el tema AJAX y callbacks y tal pero lo mejor seria que hagas una sola llamada a función, y que cuando se haya finalizado se llame a la segunda.
Como lo tienes ahora se lanza la segunda llamada antes de acabar la primera, en teoria no deberia pasar nada pero .... Como te digo se lanzaria la segunda cuando sabes que ha acabado la primera.
Además, y no sé si tiene que ver, las variables / objetos no declaradas con var, ¿en javascript era locales o globales?
En vez de poner en las 2 funciones ajax=objetoAjax(); pon var ajax=objetoAjax();
o incluso var ajax1=objetoAjax(); var ajax2=objetoAjax();
Igual estoy desbarrando, peor en el peor de los casos siempre es buena práctica declarar las variables /objetos, de hecho la consola de errores de FF te da el "warning" xD
|
|
|
En línea
|
|
|
|
KateLibby
Desconectado
Mensajes: 90
|
He hecho los cambios que propones, fran800m, pero aún así no lo consigo. Lo de llamar la segunda función cuando termine la primera ya lo probé y no funcionó, aunque igual no lo hice bien. Sería así? function AjaxDias(datos, result){ divResultado = document.getElementById(result); ajax=objetoAjax(); ajax.open("GET", "ajax_dias.php?id=" + datos); ajax.onreadystatechange=function() { if (ajax.readyState==4) { divResultado.innerHTML = ajax.responseText } } ajax.send(null) AjaxHoras(datos, 'horas') }
function AjaxHoras(datos, result){ divResultado = document.getElementById(result); ajax=objetoAjax(); ajax.open("GET", "ajax_horas.php?id=" + datos); ajax.onreadystatechange=function() { if (ajax.readyState==4) { divResultado.innerHTML = ajax.responseText } } ajax.send(null) }
<select onChange=" AjaxDias(this.value, 'dias')"> ... Gracias por vuestras respuestas.
|
|
|
En línea
|
|
|
|
adastra
Endless Learner
Ex-Staff
Desconectado
Mensajes: 885
http://thehackerway.com/
|
a lo mejor me equivoco, pero puede ser que falla por la invocación a "ajax.send(null)" desde las dos funciones, intenta hacerlo como lo tienes pero quitando esa invocación desde la primera función, incluyela solamente en la segunda función, y que sea en ese punto el momento en el que realmente se haga el envio de datos al servidor...
|
|
|
En línea
|
|
|
|
fran800m
Desconectado
Mensajes: 204
|
A ver he terminado entrando en Google porque me termino liando con la sintaxis aunque el concepto lo tengo claro. La segunda función hay que llamarla cuando sepamos que la primera ha acabado, como lo tienes puesto sigue siendo lineal. Yo me refiero: function AjaxDias(datos, result){ divResultado = document.getElementById(result); var ajax=objetoAjax(); ajax.open("GET", "ajax_dias.php?id=" + datos, true); ajax.onreadystatechange=function() { if (ajax.readyState==4) { divResultado.innerHTML = ajax.responseText; AjaxHoras(datos, 'horas'); } } ajax.send(null); } function AjaxHoras(datos, result){ divResultado = document.getElementById(result); var ajax=objetoAjax(); ajax.open("GET", "ajax_horas.php?id=" + datos, true); ajax.onreadystatechange=function() { if (ajax.readyState==4) { divResultado.innerHTML = ajax.responseText; } } ajax.send(null); } Además de ponerte la función en su sitio he añadido la declaracion de los objetos ajax con var y completa los ; (vale igual no hace falta, pero lo hago). Además a los métodos open les faltaba el tercer parámetro, el que indica el asincronismo. No he probado nada, ya nos cuentas, igual en la falta del tercer parámetro está el misterio.
|
|
|
En línea
|
|
|
|
KateLibby
Desconectado
Mensajes: 90
|
Gracias por vuestras respuestas.
Al final hubo cambios en cómo tenía que ser el formulario y me he apañado sin utilizar AJAX. De todas formas seguro que en otro momento me encuentro con el mismo problema. En cuanto lo pruebe, os cuento.
Saludos y gracias.
|
|
|
En línea
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
Como llamar automaticamente funciones AJAX ??
PHP
|
Diabliyo
|
3
|
7,813
|
28 Agosto 2008, 15:53 pm
por Ragnarok
|
|
|
[DUDA] Cargar Dll de VB y Llamar las funciones de la misma!!!!!
Programación C/C++
|
m[a]rkus
|
0
|
3,467
|
9 Agosto 2010, 18:29 pm
por m[a]rkus
|
|
|
problema checkbox onchange y php [solucionado]
PHP
|
soru13
|
0
|
2,061
|
3 Julio 2012, 15:02 pm
por soru13
|
|
|
llamar función php desde caja de texto con onchange
PHP
|
Drakaris
|
1
|
5,294
|
24 Junio 2017, 19:06 pm
por 3n31ch
|
|
|
Django no renderiza una template al llamar a su view desde ajax
Desarrollo Web
|
mamarrach0
|
0
|
3,407
|
20 Agosto 2022, 11:30 am
por mamarrach0
|
|