javascript - 如何平滑 jQuery 过滤系统的动画

标签 javascript jquery css animation phpflickr

所以我一直在研究一个过滤器系统,它允许我使用 phpFlickr 作为 CodeIgniter 中的库来显示来自 Flickr API 的数据。我目前让它运行良好并且功能齐全,尽管动画不是我想要的。我遇到的问题是,当我将内容切换到一组不同的图像时,它会突然移动到位并且没有流畅的动画。我不确定处理此动画的最佳方法是什么,因为我对动画制作还很陌生。此外,如果有办法清理代码,那就太好了。这是我的代码。

Controller

    $sets = $this->phpflickr->photosets_getList('66096679@N07');
    $recent = $this->phpflickr->photos_search(array('privacy_filter' => 5, 'user_id' => '66096679@N07'));

    foreach ($sets['photoset'] as $key => $value) {
        $setid = $value['id'];
        $photos_in_set = $this->phpflickr->photosets_getPhotos($setid, 'original_format', NULL);

        $set_array[$key] = str_replace(' ', '-', $value['title']);

        foreach ($photos_in_set['photoset']['photo'] as $key2 => $value2) {
            $photo_array[$key][$key2]['set'] = str_replace(' ', '-', $value['title']);
            $photo_array[$key][$key2]['title'] = $value2['title'];
            $photo_array[$key][$key2]['photo_url_thumb'] = $this->phpflickr->buildPhotoURL($value2, "large");
            $photo_array[$key][$key2]['photo_url_large'] = $this->phpflickr->buildPhotoURL($value2, "original");
        }

    }

    $data['photos'] = array_reverse($photo_array);
    $data['sets'] = $set_array;

查看

<div id="filter">
    <a href="#" data-id="show-all" onclick="return false">All</a>
    <?php foreach($sets as $key => $value): ?>
        <a href="#" data-id="<?= $value ?>" onclick="return false"><?= str_replace('-', ' ', $value) ?></a>
    <?php endforeach; ?>
</div>
<section id="photos">
    <?php foreach($photos as $photoset): ?>
        <?php foreach($photoset as $key): ?>
            <a class="fancybox-media" href="<?= str_replace('http:', '',$key['photo_url_large']) ?>" data-filter="<?= $key['set'] ?>">
                <img src="<?= str_replace('http:', '', $key['photo_url_thumb']) ?>" />
            </a>
        <?php endforeach; ?>
    <?php endforeach; ?>
</section>

Javascript

$(document).ready(function(){

    $( '#filter a' ).click(function() {
      var set = $(this).data('id');

      $("#photos a[data-filter='"+ set +"']").fadeIn('20');
      $("#photos a[data-filter!='"+ set +"']").fadeOut('0');

      if($(this).data('id') === 'show-all') {
        $('#photos a'). fadeIn('20');
      }
    });
});

这是一个link to a live example上面的代码。如果您能帮助我平滑动画,将不胜感激。就数据的设置方式而言,这似乎是最好的方法,因为所有图像都被列为私有(private)图像,因此它们只能在网站上使用。非常感谢任何帮助或指导,只是停滞不前。如果您对此有任何疑问,我将非常乐意相应地更新我的问题。非常感谢您的提前帮助!

最佳答案

找出下面更流畅的图像动画代码

Javascript

    $( '#filter a' ).click(function() {
       var set = $(this).data('id');

       $("#photos a[data-filter='"+ set +"']").addClass('in');
       $("#photos a[data-filter='"+ set +"']").removeClass('out hidden');
       $("#photos a[data-filter!='"+ set +"']").addClass('out hidden');
       $("#photos a[data-filter!='"+ set +"']").removeClass('in');

      if($(this).data('id') === 'show-all') {
         $("#photos a[data-filter='"+ set +"']").addClass('out hidden');
         $('#photos a').addClass('in');
         $('#photos a').removeClass('hidden out');
      }
      $('#photos a').animate({
        'left': '0',
        'top':' 0'
      });
  });

CSS

@-webkit-keyframes fadein {
   from { opacity: 0; }
   to { opacity: 1; }
}

@-webkit-keyframes fadeout {
   from { opacity: 1; }
   to { opacity: 0; }
}
.in, .out {
    -webkit-animation-timing-function: ease-in-out;
    -webkit-animation-duration: 705ms;
    -moz-animation-timing-function: ease-in-out;
    -moz-animation-duration: 705ms;        
}

.fade.out {
    z-index: 0;
    -webkit-animation-name: fadeout;
    -moz-animation-name: fadeout;
    opacity:0;
}

.fade.in {
    opacity: 1;
    z-index: 10;
    -webkit-animation-name: fadein;
    -moz-animation-name: fadein;
}

CSS 由 this stackoverflow post 提供.现在弄清楚如何预加载一些图像。

关于javascript - 如何平滑 jQuery 过滤系统的动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22418082/

相关文章:

javascript - 使用 cookie 显示/隐藏表列

jquery - 使用 class 而不是 id 的 keyup 事件

javascript - 如何修改我的代码以选择特定的复选框?

html - 如何在选择时更改/删除表单边框颜色?(Chrome)

javascript - 记录较少时如何隐藏页码

php - 使用jquery检索子div的id?

html - CSS 静态轮播 - 无法在整个页面上展开

html - 这种响应式布局可以使用 Flexbox CSS 吗?

javascript - 如何在对象文字中定义异步函数

c# - 从 $.post 传递数组到 Action