Вопрос

хорошо, я пытаюсь анимировать что-то на разных высотах, если выбранный идентификатор имеет выбранный класс.у меня есть следующий код.

 function myfunction() {


   if ($('#homebutton').hasClass("active"));
   {
    $('#content').animate({height: "240px",opacity: 1}, 100 , hideLoader());
   }

   if ($('#showbutton').hasClass("active"));
   {
   $('#content').animate({height: "79px",opacity: 1}, 200 , hideLoader());
   }

   if ($('#aboutbutton').hasClass("active"));
   {
   $('#content').animate({height: "527px",opacity: 1}, 300 , hideLoader());}

   if ($('#contactbutton').hasClass("active"));
   {
   $('#content').animate({height: "1040px",opacity: 1}, 400 , hideLoader());
   }
}

это цепочка анимаций друг за другом, независимо от того, на что я нажимаю, в итоге получается 1040 пикселей, что я делаю не так??

попробовал изменить его на

{if ($('#homebutton').hasClass("active"));
$('#content').animate({height: "240px",opacity: 1}, 100 , hideLoader());
}

абсолютно без эффекта

Это было полезно?

Решение

Вы отделили операторы if от кода в следующей строке.Единственное, что вы выполняете, когда условие истинно, - это пустой оператор.

Измени это:

if ($('#homebutton').hasClass("active"));

в:

if ($('#homebutton').hasClass("active"))

и то же самое для трех других.

Другие советы

Вы можете многое исправить, воспользовавшись приятным языком, которым является Javascript:

$.each({
  '#homebutton': { height: '240px', speed: 100 },
  '#showbutton': { height: '79px', speed: 200 },
  '#aboutbutton': { height: '527px', speed: 300 },
  '#contactbutton': { height: '1040px', speed: 400 }
}, function(selector, controls) {
  if ($(selector).hasClass('active'))
    $('#content').animate({height: controls.height, opacity: 1}, controls.speed, hideLoader());
});
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top