Глядя, чтобы сжать мой сценарий анимации Jquery - PullRequest
0 голосов
/ 02 ноября 2010

У меня есть скрипт анимации jquery, который работает должным образом, однако я чувствую, что есть способ уменьшить общую нагрузку на скрипт. Вот ссылка на страницу разработки:

http://dev.abinstallations.com

Анимация состоит из двух частей, и эти анимации применяются к шести отдельным элементам div. Отдельный скрипт применяется к каждому элементу. Например:

//First
$("#first_flip").hide();
$("#first_button_show").click(function(){
  $('#first_flip').animate({
     opacity: 'toggle',
     top: '+=524',
     height: 'toggle'}, 600, function() {
       // Animation complete.
  });
});
$("#first_button_hide").click(function(){
  $('#first_flip').animate({
     opacity: 'toggle',
     top: '-=524',
     height: 'toggle'}, 400, function() {
       // Animation complete.
  });
});

//Second
$("#second_flip").hide();
$("#second_button_show").click(function(){
  $('#second_flip').animate({
     opacity: 'toggle',
     top: '+=524',
     height: 'toggle'}, 600, function() {
       // Animation complete.
  });
});
$("#second_button_hide").click(function(){
  $('#second_flip').animate({
    opacity: 'toggle',
    top: '-=524',
    height: 'toggle'}, 400, function() {
      // Animation complete.
  });
});

... и так далее для остальных четырех элементов. Есть ли сжатый способ добиться этого?

1 Ответ

0 голосов
/ 02 ноября 2010

Вы можете вытащить его как функцию:

Hook("first");
Hook("second");

function Hook( id )
{
    $("#" + id + "_flip").hide();
    $("#" + id + "_button_show").click(function(){
      $("#" + id "_flip").animate({
         opacity: 'toggle',
         top: '+=524',
         height: 'toggle'}, 600, function() {
           // Animation complete.
      });
    });
    $("#" + id + "_button_hide").click(function(){
      $("#" + id + "_flip").animate({
         opacity: 'toggle',
         top: '-=524',
         height: 'toggle'}, 400, function() {
           // Animation complete.
      });
    });
}

Или даже заставить функцию принимать несколько параметров и перебирать их.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...