结合砌体,imagesLoaded与ajax功能

alx*_*xvo 1 javascript ajax jquery jquery-masonry

我正在制作一个网站,其中所有内部链接使当前页面淡出并且新页面淡入.这对我来说非常有用.问题是我正在尝试将它与伟大的砌体插件结合起来.在第一个页面加载砌体确实有效,但我似乎无法弄清楚如何通过ajax重新激活新加载的内容上的砌体.我应该补充一下,当前砌体中的所有项目都会被删除,然后被新的替换.

砌体代码是这样的:

    $container = $('#container');

    $container.imagesLoaded(function(){ 
        $container.masonry({
           itemSelector: '.item',
           transitionDuration: 0
        }); 
    });
Run Code Online (Sandbox Code Playgroud)

而ajax加载代码是这样的:

    var newHash      = "",
        $mainContent = $("#ajaxcontainer"),
        $ajaxSpinner = $("#loader"),
        $el;

    $('.internal').each(function() {
        $(this).attr("href", "#" + this.pathname);
    }); 

    $(document).on('click', '.internal', function() {

        window.location.hash = $(this).attr("href");

    });

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

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

        if (newHash) {
            $mainContent.fadeOut(500, function() {

                $ajaxSpinner.fadeIn();
                $mainContent.load(newHash + " #container", function() {
                    $ajaxSpinner.fadeOut( function() {
                        $mainContent.fadeIn(1000);
                    });
                    $('.internal').each(function() {
                        $(this).attr("href", "#" + this.pathname);
                    });        
                });

            });
        };

    });

    $(window).trigger('hashchange');
Run Code Online (Sandbox Code Playgroud)

有没有人有任何关于如何实现这一目标的意见?非常感谢你.

alx*_*xvo 7

我终于设法让它上班了!

我希望其他人会觉得这很有帮助,所以我将它发布在这里供将来参考.

我遇到的一个问题似乎是我在加载数据时隐藏了容器.我用fadeOut和fadeIn隐藏它,这似乎导致砌体问题.隐藏它本身,我现在将不透明度设置为0,并在加载数据后返回1.脚本如下:

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

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

    if (newHash) {
        $('#ajaxcontainer').fadeTo(500, 0, function() {

            $ajaxSpinner.fadeIn();
            $mainContent.empty();
            $.get(newHash, function(data){

                var $data = $(data).find("#container > *");

                $container.prepend($data).imagesLoaded(function(){
                    $container.masonry( 'prepended', $data, true );
                });

                $ajaxSpinner.fadeOut( function() {
                    $('#ajaxcontainer').fadeTo(1000, 1);
                });     
            });

        });
    };

});
Run Code Online (Sandbox Code Playgroud)