为ajax内容添加淡入淡出效果

时间:2015-05-20 15:13:19

标签: javascript ajax wordpress fade

我有一个wordpress网站,当我点击一个按钮后,我的加载器后面出现了ajax内容。该代码效果很好,但我想添加当前内容淡出的效果,新内容将淡入,不再需要加载器。

1.    
jQuery(document).ready(function() {
        jQuery('#main-content').on('click', '.jax a, .page-navigation a', function(e) {
            e.preventDefault();
            var url = jQuery(this).attr('href'),
                title = jQuery(this).attr('title')
            ;
            jQuery('#main-content').html('<img id="loader" alt="loading" width="43" height="11" src="<?php echo get_template_directory_uri(); ?>/library/images/squares.gif"/ >').load(url+ ' #main-content');
            document.title = title;
            history.pushState({url:url,title:title}, title, url );
          });
        });

window.onpopstate = function(event) {
    document.title = event.state.title;
    jQuery('#main-content').html('<img id="loader" alt="loading" width="43" height="11" src="<?php echo get_template_directory_uri(); ?>/library/images/squares.gif"/ >').load(event.state.url+ ' #main-content');
}

我尝试过多种变体,例如下面的内容,但是它可以正常工作,但它并不像第一个例子中那样更新地址网址和每个帖子。

2.
jQuery('.jax a, .page-navigation a').live('click', function(event) {
            var link = $(this).attr('href');
            jQuery('#main-content').fadeOut('slow', function(){
        jQuery('#main-content').load(link+' #main-content', function(){
            jQuery('#main-content').fadeIn('slow');
        });
    });
            return false;
});

知道如何在第一个示例中添加淡入淡出或使用第二个示例添加地址URL更新(历史记录API)吗?

1 个答案:

答案 0 :(得分:1)

我没有为您提供解决方案,但也许这个问题的答案可以帮助您: https://stackoverflow.com/a/1789347/4867333

  

load的调用将使用AJAX并将以异步方式运行。您将在通话结束后立即淡入。您可以通过将回调传递给load来实现。您的代码将如下所示:

     

$('#content').load("page1.html", {}, function() { $(this).fadeIn("normal"); }));

     

有关详细信息,请参阅documentation on jQuery's .load()

或者这个:

https://stackoverflow.com/a/9337696/4867333

他能够通过将效果应用于包装器div来实现fadeOut,fadeIn。

您可以尝试以下方法:

jQuery('.jax a, .page-navigation a').live('click', function(event) {
        var url = jQuery(this).attr('href'),
            title = jQuery(this).attr('title');
        jQuery('#main-content').fadeOut('slow', function(){
    jQuery('#main-content').load(url+' #main-content', function(){
        jQuery('#main-content').fadeIn('slow');
        document.title = title;
        history.pushState({url:url,title:title}, title, url );
    });
});
        return false;
});