1

我确定这很简单,但我不明白。

我正在使用以下 AJAX 脚本将外部页面的特定 div 中的内容加载到我的根页面上的同名 div 中。

    $(function() {

    var newHash      = "",
        $mainContent = $("#main-content"),
        $pageWrap    = $("#page-wrap"),
        $el;


    $(document).delegate(".dyn a", "click", function() {
        window.location.hash = $(this).attr("href");
        return false;
    }); 


    $(window).bind('hashchange', function(){

        newHash = window.location.hash.substring(1);

        if (newHash) {

            $mainContent
                .find("#guts")
                .fadeOut(200, function() {
                    $mainContent.hide().load(newHash + " #guts", function() {
                        $mainContent.fadeIn(200, function() {
                            $pageWrap.animate({

                            });

                        });
                        $(".dyn a").removeClass("current");
                        $(".dyn a[href="+newHash+"]").addClass("current");
                    });
                });
        };

    });
    $(window).trigger('hashchange');
});

有人可以帮我更改我正在加载的页面标题的根页面标题吗?

我试过使用:

var newTitle = $(responseHtml).filter('title').text();
document.title = newTitle;

正如它在这篇文章中提到的那样,它几乎可以正常工作,但会阻止 ajax 正常运行。我不确定,但我是否将其放置在正确的位置。

提前致谢!

4

2 回答 2

1

你可能想要:window.top.document.title = newTitle;

于 2012-07-25T15:41:43.527 回答
1

我设法通过将以下内容添加到 hashchange 函数来实现这一点:

   String.prototype.toTitleCase = function(n) {
   var s = this;
   if (1 !== n) s = s.toLowerCase();
   return s.replace(/\b[a-z]/g,function(f){return f.toUpperCase()});
   }

   newHash = window.location.hash.substring(1);         

   function changeTitle(title) { 

   document.title = window.location.hash.replace("#","").replace(/[_]/g,"").replace(".html","").replace("and","+").toTitleCase(); }
   changeTitle("");

这从页面文件名中获取标题,删除哈希和任何下划线,然后将每个单词的第一个字母大写。

我确信有一种更好、更简单的方法可以做到这一点。我现在要做的就是。

于 2012-07-31T20:17:19.500 回答