Hola, hos cuento mi problema sobre una funcion js que no consigo hacerla funcionar como yo quiero, se trata de un archivo xml que a traves de una funcion cambio su contenido de forma dinamica, hasta aqui bien. Pero cada vez que cambio el archivo xml llamo a otra funcion js llamada mostrarnombres donde esta llama a otra funcion llamada mostrarregistro donde pretendo mostrar los datos del archivo xml con un intervalo de 10 segundo, lo que pasa que cada vez que cambio el xml y posterior mente llamo a la funcion mostrarnombres que llama a mostrarregistro me tarda 10 segundos en mostrar los resultados en pantalla, pero esto es lo que no quiero osea que cuando llame a mostrarnombre me muestre el primer resultado al momento pero despues el seguiente nombre me lo muestro pasado 10 segundo y asin sucesivamente pero cada vez que cambio el xml que no me tarde 10 segundo en mostrarme la funcion muestro codigo por si me podeis decir como hacerlo.
esta es la funcion que me muestra los datos en uno en uno cambiandolo
var procesamiento, xml = null, contador=0;
Código Javascript
:
Ver originalfunction MostrarRegistro() {
try {
document.getElementById("registro").innerHTML ='<p>'+ xml.getElementsByTagName('nombre')[contador].firstChild.nodeValue+'</p>';
contador ++;
}
catch(e) {
try { window.clearInterval(procesamiento); } catch(e) {}
contador = 0;
}
}
esta es la funcion que llama a mostrarregistro dandole un intervalo de 10 seg
Código Javascript
:
Ver originalfunction MostrarNombres() {
var ajax = obtiene_http_request();
ajax.open('get','archivo.xml');
ajax.onreadystatechange = function() {
if(ajax.readyState == 4){
if(ajax.status == 200) {
xml=ajax.responseXML;
if(xml.getElementsByTagName('nombre').length > 0)
procesamiento = window.setInterval(MostrarRegistro, 10000);
}
}
}
ajax.send(null);
}
aqui la funcion que me cambia el xml y posteriormente llama a mostrarnombres
Código Javascript
:
Ver originalfunction pedir_xml(){
//................
if(ajax.readyState == 4){
if(ajax.status == 200) {
//................
MostrarNombres();
}
}
}
saludos.