Foros del Web » Programando para Internet » Javascript »

Como manipular objecto History (pushstate,popstate) para cuando hago un refresh o F5

Estas en el tema de Como manipular objecto History (pushstate,popstate) para cuando hago un refresh o F5 en el foro de Javascript en Foros del Web. hola tengo el sgte. problema, cuando aprieto F5 o refresco la pagina con el boton del browser, este me manda al link de la url ...
  #1 (permalink)  
Antiguo 08/02/2016, 19:10
 
Fecha de Ingreso: mayo-2009
Mensajes: 5
Antigüedad: 15 años, 5 meses
Puntos: 0
Como manipular objecto History (pushstate,popstate) para cuando hago un refresh o F5

hola
tengo el sgte. problema, cuando aprieto F5 o refresco la pagina con el boton del browser, este me manda al link de la url pero perdiendo parte del contenido.
Al seleccionar el boton page1 se carga en la parte de abajo el contenido lo cual esta OK (AJAX)

pero al apretar el F5 o el boton refresh del navegador solo muestra la parte de la page1 y no junto con el index

los botones forward y back funcionan OK, solo me falta lo del boton refrescar, esto esta hecho con el objeto de history en html5 y js

archivo index.jsf
Código PHP:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
<
html xmlns="http://www.w3.org/1999/xhtml"
      
xmlns:h="http://java.sun.com/jsf/html"
      
xmlns:f="http://java.sun.com/jsf/core"
      
xmlns:ui="http://java.sun.com/jsf/facelets"
      
xmlns:p="http://primefaces.org/ui" 
    <
h:head>
        <
title>CNR</title>
        <
script type="text/javascript" src="../resources/js/jquery-1.11.3.min.js"></script>
        
        <script type="text/javascript">
        //jQuery.noConflict();
        </script>
        <script type="text/javascript" src="index.js"></script>
        <style type="text/css">
        img.ajax-loader
            {
                position: absolute;
                top: 45%;
                left: 45%;
                display: none;
            }
        </style>
    </h:head>
    <h:body>
    <img class="ajax-loader" src="http://www.forosdelweb.com/f13/resources/images/spinner.gif" alt="loading..." />
    <div id="header">
        <nav>
            <ul>
                <li><strong>index</strong></li>
                <li><a id="aHistoryPage1" href="page1.jsf">page1</a></li>
                <li><a id="aHistoryPage2" href="page2.jsf">page2</a></li> 
            </ul>
        </nav>
        <button id="previous">Previous</button>
     
        <button id="forward">Forward</button>
        <p>Number of pages in the history stack: <span></span></p>
    </div>
    <div id="contenido"></div>
    </h:body>
</html> 
archivo index.js
Código PHP:
$(document).ready(function (){ 
    $(
'#previous').click(function(){ 
        
window.history.back(); 
    }); 

    $(
'#forward').click(function(){ 
        
window.history.forward(); 
    }); 

    function 
loadView(view,elementResponse,titulo,debug) { 
        
        if(
elementResponse == "" || elementResponse == "undefined"){
            
console.log("Debes ingresar un elemento para mostrar/cargar la respuesta desde el servidor");
            return 
false;
        }
        if(
titulo == "" || titulo == "undefined"){
            
titulo jQuery("title").text();
        }
        if(
titulo == "" || titulo == "undefined"){
            
debug=false;
        }
        
        if(
window.history.state == null){
            
elementResponse.html("");
            return 
"index.jsf";
        }else
            if (
typeof window.history.pushState == 'function') { 
//                if(keyCode==116){
//                    window.history.replaceState("page1.jsf", "", "page1.jsf"); 
//                }
                
                
elementResponse.load(view);
                $(
'.ajax-loader').show();
                $.
ajax({
                    
urlview '?type=ajax'success: function (data) {
                        
elementResponse.html(data);
                        $(
'.ajax-loader').hide();
                    }
                });
                
jQuery("title").html(titulo);
            }
        if(
debug==true){
            
console.log(window.history.length); 
        }
        
        
window.onpopstate = function(event){ 
            
loadView(window.history.state,elementResponse,"",debug);
        };         
    } 

    $(
'#aHistoryPage1,#aHistoryPage2').on('click',function(event) { 
        
        
window.history.pushState($(this).attr('href'), null, $(this).attr('href')); 
        
loadView($(this).attr('href'),jQuery("#contenido"),"",false); 
        return 
event.preventDefault(); 
    }); 

    
    
//window.history.replaceState($('strong').text(), null, $('strong').text()); 
    //printHistoryLength(); 

    
}); 
archivo page1.jsf
Código PHP:
<div>
        
hola soy la pagina 111
    
</div

gracias

Última edición por climax; 08/02/2016 a las 19:18

Etiquetas: ajax, funcion, history, html, js, manipular, refresh
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 14:33.