我正在尝试使用 ajax 从另一个页面加载 div,但使用 History API 维护 URL 完整性。ajax 和历史部分正在工作(即 div 正在加载并且 url 正在更改),但由于某种原因,我的 div 包含我的整个页面,而不仅仅是 div 中的内容!
原始页面和正在加载的页面 div 都是这种情况。
剥离 HTML
<!DOCTYPE html>
<html>
  <body>
    <div id="slider">
        ... all the page content
        <a rel='tab' href="p/password.jsf">Forgot password?</a>
    </div>
  </body>
</html>
JS
<script>
    $(function(){
        $("a[rel='tab']").click(function(e){
            //get the link location that was clicked
            pageurl = $(this).attr('href');
            //to get the ajax content and display in div with id 'content'
            $.ajax({
                url:pageurl + '?rel=tab',
                success: function(data){
                    $('#slider').html(data);
                }});
            //to change the browser URL to 'pageurl'
            if(pageurl!=window.location){
                window.history.pushState({path:pageurl},'',pageurl);    
            }
            return false;  
        });
    });
    /* the below code is to override back button to get the ajax content without reload*/
    $(window).bind('popstate', function() {
        $.ajax({
            url:location.pathname+'?rel=tab',
            success: function(data){
                $('#slider').html(data);
            }});
    });
</script>