Фильтр Jquery Quicksand + prettyphoto не работает после загрузки содержимого ajax - PullRequest
0 голосов
/ 04 марта 2011

Я тестирую скрипт quicksand для фильтрации некоторых изображений.

Я реализовал скрипт с некоторым изображением ДЕМО ЗДЕСЬ .
Как видите, есть круг, пятиугольник и треугольник разного цвета.
Фильтр прекрасно работает в этом встроенном скрипте:

<script type="text/javascript" charset="utf-8">
    (function($) {
        $.fn.sorted = function(customOptions) {
            var options = {
                reversed: false,
                by: function(a) {
                    return a.text();
                }
            };
            $.extend(options, customOptions);

            $data = $(this);
            arr = $data.get();
            arr.sort(function(a, b) {

                var valA = options.by($(a));
                var valB = options.by($(b));
                if (options.reversed) {
                    return (valA < valB) ? 1 : (valA > valB) ? -1 : 0;              
                } else {        
                    return (valA < valB) ? -1 : (valA > valB) ? 1 : 0;  
                }
            });
            return $(arr);
        };

    })(jQuery);

    $(function() {

      var read_button = function(class_names) {
        var r = {
          selected: false,
          type: 0
        };
        for (var i=0; i < class_names.length; i++) {
          if (class_names[i].indexOf('selected-') == 0) {
            r.selected = true;
          }
          if (class_names[i].indexOf('segment-') == 0) {
            r.segment = class_names[i].split('-')[1];
          }
        };
        return r;
      };

      var determine_sort = function($buttons) {
        var $selected = $buttons.parent().filter('[class*="selected-"]');
        return $selected.find('a').attr('data-value');
      };

      var determine_kind = function($buttons) {
        var $selected = $buttons.parent().filter('[class*="selected-"]');
        return $selected.find('a').attr('data-value');
      };

      var $preferences = {
        duration: 800,
        easing: 'easeInOutQuad',
        adjustHeight: false
      };

      var $list = $('#list');
      var $data = $list.clone();

      var $controls = $('ul.splitter ul');

      $controls.each(function(i) {

        var $control = $(this);
        var $buttons = $control.find('a');

        $buttons.bind('click', function(e) {

          var $button = $(this);
          var $button_container = $button.parent();
          var button_properties = read_button($button_container.attr('class').split(' '));      
          var selected = button_properties.selected;
          var button_segment = button_properties.segment;

          if (!selected) {

            $buttons.parent().removeClass('selected-0').removeClass('selected-1').removeClass('selected-2').removeClass('selected-3').removeClass('selected-4').removeClass('selected-5').removeClass('selected-6');
            $button_container.addClass('selected-' + button_segment);

            var sorting_type = determine_sort($controls.eq(1).find('a'));
            var sorting_kind = determine_kind($controls.eq(0).find('a'));

            if (sorting_kind == 'all') {
              var $filtered_data = $data.find('li');
            } else {
              var $filtered_data = $data.find('li.' + sorting_kind);
            }

            if (sorting_type == 'size') {
              var $sorted_data = $filtered_data.sorted({
                by: function(v) {
                  return parseFloat($(v).find('span.colore').text());
                }
              });
            } else {
              var $sorted_data = $filtered_data.sorted({
                by: function(v) {
                  return $(v).find('strong').text().toLowerCase();
                }
              });
            }

            $list.quicksand($sorted_data, $preferences);

          }

          e.preventDefault();
        });

      }); 

      var high_performance = true;  
      var $performance_container = $('#performance-toggle');
      var $original_html = $performance_container.html();

      $performance_container.find('a').live('click', function(e) {
        if (high_performance) {
          $preferences.useScaling = false;
          $performance_container.html('CSS3 scaling turned off. Try the demo again. <a href="#toggle">Reverse</a>.');
          high_performance = false;
        } else {
          $preferences.useScaling = true;
          $performance_container.html($original_html);
          high_performance = true;
        }
        e.preventDefault();
      });
    });
</script>

Я также включил скрипт prettyphoto для эффекта лайтбокса.

Проблема в том, что скрипт prettyphoto перестает работать после того, как я использую фильтр. Я понял, что это вызвано перезагрузкой контента ajax.
Мне нужно "перезагрузить" prettyphoto , как объяснено также на официальном форуме prettyphoto

Я пытался с

function reloadPrettyPhoto() {
$(".pp_pic_holder").remove();   
$(".pp_overlay").remove();
$(".ppt").remove();
    $("a[rel^='prettyPhoto']").prettyPhoto();

}

и я вызываю функцию вокруг строки 112, после

    $list.quicksand($sorted_data, $preferences);

      }
// Try to reload prettyphoto
reloadPrettyPhoto();
e.preventDefault();

    });

... естественно без результатов: (

Я пробовал также с:

jQuery.ajaxStop(function(){
    $("a[rel^='prettyPhoto']").prettyPhoto();
    });

Но ничего.

Я не могу понять, как использовать в моем сценарии

jQuery.ajaxStop(function(){
// Code to be run.
});

как и пользователь форума рекомендует

Заранее спасибо за помощь!

Ответы [ 3 ]

7 голосов
/ 14 апреля 2011

Вам действительно нужно повторно инициализировать prettyPhoto после выполнения зыбучего песка.

Я взял вам пример страницы и изменил эту строку:

$list.quicksand($sorted_data, $preferences);

Стать:

$list.quicksand($sorted_data, $preferences, function(){ $("a[rel^='prettyPhoto']").prettyPhoto(); });

Таким образом, каждый раз, когда контент фильтруется, prettyPhoto будет обновляться.

Вы можете увидеть, как это работает здесь: http://no -margin-for-errors.com / demos / quicksand / quicktest.html

Спасибо

1 голос
/ 17 марта 2011

Вы пытались позвонить prettyPhoto по обратному вызову Quicksand?

Вот пример с сайта Quicksand:

$('#source').quicksand( $('#destination li'), {
    name: value
}, function() {
    // callback code
});

У меня был хороший опыт работы с Quicksand и другими вещами вместе с ним на www.lovecreativity.co.uk - посмотрите, поможет ли это вам вообще?

Удачи

0 голосов
/ 26 декабря 2012

Как сказал scaron, вы должны попробовать заменить

$list.quicksand($sorted_data, $preferences);

с

$list.quicksand($sorted_data, $preferences, function(){ $("a[rel^='prettyPhoto']").prettyPhoto(); });

И в своем коде проверьте, что ваш атрибут rel читает «prettyphoto» вместо «prettyPhoto», с большой буквы P, может быть, это просто так?

...