Tengo ya buen tiempo sin saber que hacer, dándole vueltas al asunto y sin encontrar alguna solución, la cuestión es que como comento en el título, tengo una navegación mediante AJAX que encontré por allí, y funciona muy bien.
Mi problema viene que cuando cargo la página que tiene un slider de materialize iniciado en un archivo JS que se junto con el otro contenido del AJAX, me explico: Tengo una serie de páginas, en una de ellas hay un carousel o sider que se inicializa con la funcion $('.carousel').carousel({parámetros}); todo el contenido html que especifiqué en la página se muestra bien, pero la función no se ejecuta y por tanto no me muestra el carousel, les adjunto unas imágenes para que me logren entender.
Cuando se carga accediendo directamente a la url en el navegador:
Y aquí cuando se carga la página mediante AJAX:
Cabe destacar que tengo un div principal con una id wrapper, donde se carga todo el contenido, excluyendo el footer, las cabeceras y el menú de navegación. Les dejo un ejemplo del código:
Código PHP:
Ver original
<?php $page_title = "Inicio"; $as_json = false; $as_json = true; } else { include('static/common/topsite.php'); ?> <div id="wrapper"> <?php } ?> <div class="container"> <div class="overlay"><img src="cdn/img/logo.png" alt="Agentes del Infinito"></div> </div> <!-- MaterializeCSS --> <script src="cdn/js/jquery-3.3.1.min.js"></script> <script src="cdn/js/materialize.min.js"></script> <script src="cdn/js/navigation.js"></script> <script src="cdn/js/init.js"></script> <?php if($as_json){ } else { ?> </div> <?php include('static/common/footer.php'); } ?>
También les voy a dejar el código para la navegación en ajax, quizá el error está ahí.
Código Javascript:
Ver original
"use strict"; var ajaxRequest = new (function () { function closeReq () { oLoadingBox.parentNode && document.body.removeChild(oLoadingBox); bIsLoading = false; } function abortReq () { if (!bIsLoading) { return; } oReq.abort(); closeReq(); } function ajaxError () { alert("Unknown error."); } function ajaxLoad () { var vMsg, nStatus = this.status; switch (nStatus) { case 200: vMsg = JSON.parse(this.responseText); document.title = oPageInfo.title = vMsg.page; document.getElementById(sTargetId).innerHTML = vMsg.content; if (bUpdateURL) { history.pushState(oPageInfo, oPageInfo.title, oPageInfo.url); bUpdateURL = false; } break; default: vMsg = nStatus + ": " + (oHTTPStatus[nStatus] || "Unknown"); switch (Math.floor(nStatus / 100)) { case 1: console.log("Information code " + vMsg); break; case 2: console.log("Successful code " + vMsg); break; case 3: console.log("Redirection code " + vMsg); break; case 4: console.log("Client Error #" + vMsg); break; case 5: console.log("Server Error #" + vMsg); break; default: ajaxError(); } } closeReq(); } function filterURL (sURL, sViewMode) { return sURL.replace(rSearch, "") + ("?" + sURL.replace(rHost, "&").replace(rView, sViewMode ? "&" + sViewKey + "=" + sViewMode : "").slice(1)).replace(rEndQstMark, ""); } function getPage (sPage) { if (bIsLoading) { return; } oReq = new XMLHttpRequest(); bIsLoading = true; oReq.onload = ajaxLoad; oReq.onerror = ajaxError; if (sPage) { oPageInfo.url = filterURL(sPage, null); } oReq.open("get", filterURL(oPageInfo.url, "json"), true); oReq.send(); oLoadingBox.parentNode || document.body.appendChild(oLoadingBox); } function requestPage (sURL) { if (history.pushState) { bUpdateURL = true; getPage(sURL); } else { location.assign(sURL); } } function processLink () { if (this.className === sAjaxClass) { requestPage(this.href); return false; } return true; } function init () { oPageInfo.title = document.title; history.replaceState(oPageInfo, oPageInfo.title, oPageInfo.url); for (var oLink, nIdx = 0, nLen = document.links.length; nIdx < nLen; document.links[nIdx++].onclick = processLink); } const sTargetId = "wrapper", sViewKey = "view_as", sAjaxClass = "goto", rSearch = /\?.*$/, rHost = /^[^\?]*\?*&*/, rView = new RegExp("&" + sViewKey + "\\=[^&]*|&*$", "i"), rEndQstMark = /\?$/, oLoadingBox = document.createElement("div"), oCover = document.createElement("div"), oLoadingSpin = document.createElement("div"), oPageInfo = { title: null, url: location.href }, oHTTPStatus = { 100: "Continue", 101: "Switching Protocols", 102: "Processing", 200: "OK", 201: "Created", 202: "Accepted", 203: "Non-Authoritative Information", 204: "No Content", 205: "Reset Content", 206: "Partial Content", 207: "Multi-Status", 208: "Already Reported", 226: "IM Used", 300: "Multiple Choices", 301: "Moved Permanently", 302: "Found", 303: "See Other", 304: "Not Modified", 305: "Use Proxy", 306: "Reserved", 307: "Temporary Redirect", 308: "Permanent Redirect", 400: "Bad Request", 401: "Unauthorized", 402: "Payment Required", 403: "Forbidden", 404: "Not Found", 405: "Method Not Allowed", 406: "Not Acceptable", 407: "Proxy Authentication Required", 408: "Request Timeout", 409: "Conflict", 410: "Gone", 411: "Length Required", 412: "Precondition Failed", 413: "Request Entity Too Large", 414: "Request-URI Too Long", 415: "Unsupported Media Type", 416: "Requested Range Not Satisfiable", 417: "Expectation Failed", 422: "Unprocessable Entity", 423: "Locked", 424: "Failed Dependency", 425: "Unassigned", 426: "Upgrade Required", 427: "Unassigned", 428: "Precondition Required", 429: "Too Many Requests", 430: "Unassigned", 431: "Request Header Fields Too Large", 500: "Internal Server Error", 501: "Not Implemented", 502: "Bad Gateway", 503: "Service Unavailable", 504: "Gateway Timeout", 505: "HTTP Version Not Supported", 506: "Variant Also Negotiates (Experimental)", 507: "Insufficient Storage", 508: "Loop Detected", 509: "Unassigned", 510: "Not Extended", 511: "Network Authentication Required" }; var oReq, bIsLoading = false, bUpdateURL = false; oLoadingBox.id = "loader"; oCover.className = "progress red accent-1"; oLoadingSpin.className = "indeterminate red darken-2"; oCover.onclick = abortReq; oCover.appendChild(oLoadingSpin); oLoadingBox.appendChild(oCover); onpopstate = function (oEvent) { bUpdateURL = false; oPageInfo.title = oEvent.state.title; oPageInfo.url = oEvent.state.url; getPage(); }; window.addEventListener ? addEventListener("load", init, false) : window.attachEvent ? attachEvent("onload", init) : (onload = init); this.open = requestPage; this.stop = abortReq; this.rebuildLinks = init; })();
Además tengo la sospecha de que no solo esos elementos se verán afectados. también inputs y cosas así.
Espero me puedan ayudar, muchas gracias de antemano y si necesitan algo más, por favor háganmelo saber.