Jquery BBQ, вызов функции вместо hide() или show() для лучшего эффекта?

Я пытаюсь выяснить, как расширить библиотеку BBQ для поддержки некоторых основных функций, но в настоящий момент я не могу этого сделать. Я создаю сайт загрузки портфолио AJAX и следую этому примеру http://benalman.com/code/projects/jquery-bbq/examples/fragment-basic/

У меня есть макет изотопной сетки, и при нажатии на элемент я хотел бы, чтобы сетка исчезла, а контент AJAX исчез. Я использую переходы CSS3 для ускорения аппаратного обеспечения, так что вне Пример коробки не делает именно то, что нравится.

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


var url = $.param.fragment();


$( 'a.bbq-current' ).removeClass( 'bbq-current' );

// Hide any visible ajax content.            
$( '.site-container' ).children( ':visible').hide();

if ( cache[ url ] ) {
// Since the element is already in the cache, it doesn't need to be
// created, so instead of creating it again, let's just show it!
cache[ url ].show();

} else {
  // Show "loading" content while AJAX content loads.
  $( '#load' ).show();

  // Create container for this url's content and store a reference to it in
  // the cache.
  cache[ url ] = $( '<div class="ajax-item"/>' )

  // Append the content container to the parent container.
  .appendTo( '.site-container' )

  // Load external content via AJAX. Note that in order to keep this
    // example streamlined, only the content in .infobox is shown. You'll
    // want to change this based on your needs.

  .load(url+' .work-detail', function(){
      // Content loaded, hide "loading" content.
      $( '#load' ).hide();
      $('.work-detail').addClass('work-detail-show');
    });
   }
   })

   // Since the event is only triggered when the hash changes, we need to trigger
   // the event now, to handle the hash the page may have loaded with.
$(window).trigger( 'hashchange' );

});

В идеале я хотел бы сделать это для скрытия / шоу

    $( '.site-container' ).children( ':visible').runSomeFunction();
    cache[ url ].runSomeOtherFunction,''();

С этими функциями что-то вроде

    function runSomeFunction() {
    $(this).addClass('fadeOut');//Adds class which changes scale and opacity
    setTimeout(function(){$(this).hide();}, 700);//Removes div
});

В настоящее время я получаю ошибки "runSomeFunction is not function" при попытке выполнить приведенный выше пример.

0 ответов

Другие вопросы по тегам