Tengo un script en ajax que sirve para refrescar cieto div con informacion de un php.
La duda que tengo es que a veces cuando monto el script en mi host, cuando accedo, se demora en cargar, entonces queria ver la manera de hacer para mostrar un mensaje mientras carga como: "Cargando...", en el mismo div donde se mostraria la informacion del php.
Este es mi codigo:
Código Javascript:
Se que si el http_request.readyState es igual a 1, significa que todavia no esta completo, que recien se inicia el proceso. Pero no sabria como modificar mi codigo para poder mostrar el mensaje de "Cargando..." cuando todavia no se completa.Ver original
var http_request = false; function makePOSTRequest(url, parameters, funcion) { http_request = false; if (window.XMLHttpRequest) { // Mozilla, Safari,... http_request = new XMLHttpRequest(); if (http_request.overrideMimeType) { // set type accordingly to anticipated content type //http_request.overrideMimeType('text/xml'); http_request.overrideMimeType('text/html'); } } else if (window.ActiveXObject) { // IE try { http_request = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { http_request = new ActiveXObject("Microsoft.XMLHTTP"); } catch (e) {} } } if (!http_request) { alert('Cannot create XMLHTTP instance'); return false; } http_request.onreadystatechange = funcion; http_request.open('POST', url, true); http_request.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); http_request.setRequestHeader("Content-length", parameters.length); http_request.setRequestHeader("Connection", "close"); http_request.send(parameters); } function alertContents() { if (http_request.readyState == 4) { if (http_request.status == 200) { //alert(http_request.responseText); result = http_request.responseText; document.getElementById('div').innerHTML = result; } else { alert(http_request.status); } } } function get() { var poststr = "codigo=" + encodeURI( document.getElementById("producto_id").value ); makePOSTRequest('generar_producto.php', poststr, alertContents); }
Alguna idea?
Muchas gracias!