¿Cómo puedo usar javascript para determinar si un HTMLScriptElement ya se ha cargado por completo?Evento de carga de Javascript: ¿cómo saber si el script ya está cargado?
¿Cómo puedo determinar si un script de carga dinámica se ha terminado de cargar sin utilizando el proceso de carga o eventos de cambio onreadystate?
código es el siguiente:
TOOL.loadScript = function (url, callback, reappend, deepSearch) {
var head, curr, child, tempScript, alreadyAppended, queue,
alreadyHandled, script, handler, loadFunc;
head = document.getElementsByTagName("head")[0];
tempScript = document.createElement("script");
tempScript.src = url;
alreadyAppended = false;
queue = [];
if (deepSearch) {
// search entire document
queue.push(document.firstElementChild);
}
else {
// just search the head element
queue.push(head);
}
while (queue.length !== 0) {
curr = queue.shift();
// add child nodes to queue
child = curr.firstElementChild;
if (child !== null && child !== undefined) {
queue.push(child);
child = child.nextElementSibling;
while (child !== null && child !== undefined) {
queue.push(child);
child = child.nextElementSibling;
}
}
if (curr.tagName !== null && curr.tagName !== undefined) {
if (curr.tagName.toLowerCase() === "script" && curr.src === tempScript.src) {
script = curr;
alreadyAppended = true;
break;
}
}
}
if (!alreadyAppended) {
script = document.createElement("script");
script.type = "text/javascript";
script.async = true;
script.src = url;
}
alreadyHandled = false;
handler = function (event) {
console.log("handling event...");
if (!alreadyHandled) {
if ((!event.readyState) || (event && (event.readyState === "loaded" || event.readyState === "complete"))) {
alreadyHandled = true;
callback.apply(script, [url]);
if (loadFunc) {
loadFunc.apply(script, arguments);
}
}
}
};
if (script.onreadystatechange === undefined) {
loadFunc = script.onload;
script.onload = handler;
}
else {
loadFunc = script.onreadystatechange;
script.onreadystatechange = handler;
}
Necesito ayuda aquí. Quiero que la función de devolución de llamada se active incluso si alreadyAppeneded === true
y el mismo script ya estaba cargado, pero solo si el script está completamente terminado de cargarse.
if (!alreadyAppended || (alreadyAppended && reappend)) {
head.appendChild(script);
}
};
CONCLUSIÓN: ¿Cómo determinar si un script ha terminado de cargarse? Por favor, hágame preguntas si es necesario.
Gracias.
Nota * Esto no verifica que haya nada cargado, solo que el elemento fue creado. – Stephen
Hombre ... muchas gracias por recordarme esta posibilidad. Estaba tratando de resolver un problema de scripts duplicados que se insertan en la misma página y ahora está arreglado. Si solo hubiera visto esto hace 6 horas. :RE –