在jquery中创建无限循环,并像心跳一样创造效果

时间:2016-05-10 08:26:51

标签: jquery web frontend

我想创建一个无限循环,它会像心跳一样影响div元素。这是我的代码:

$(document).ready(function() {
  if (!($('div').hasClass("beat"))) {
    $('div').addClass('beat')
  } else {
    $('div').removeClass("beat")
  }
});
#div {
  width: 250px;
  height: 100px;
  background: red;
  margin-top: 200px;
  margin-left: 250px;
  transition-duration: 2s;
}
.beat {
  transform: scale(1.5);
  transition-duration: 2s;
  background: blue;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="div"></div>

这是jsfiddle中的代码,但它有问题。请给我一个解决方案。感谢。

4 个答案:

答案 0 :(得分:1)

您可以使用setInterval or requestAnimationFrame执行此操作,但使用CSS keyframe animation可能最简单。

答案 1 :(得分:1)

我使用jquery on来获取transitionend个事件。但我同意,使用CSS动画将是一种更好的方法。

$("body").on("webkitTransitionEnd oTransitionend oTransitionEnd msTransitionEnd transitionend", "div", function(event) {
   toggleFun(); // toggles classes.
});

请参阅此fiddle

答案 2 :(得分:0)

当我弄乱你的代码时,干扰的是CSS转换时间。因为您的JS代码在动画完成之前调用下一步(添加或删除类)。

解决这个问题的一种方法是.on('webkitTransitionEnd otransitionend oTransitionEnd msTransitionEnd transitionend', function(e) {})方法。

但是因为我不太熟悉过渡结束自己而且更多的是反复试验,所以我在一个自我调用函数中使用了.setTimeout()。为此,我从CSS中删除了转换时间并更改了JS。

#div {
    width: 250px;
    height: 100px;
    background: red;
    margin-top: 200px;
    margin-left: 250px;
}

.beat {
    transform: scale(1.5);
    background: blue;
}



$( document ).ready(function() {
    function heartbeat() {
        setTimeout(function(){                //start setTimeout
            $('#div').toggleClass('beat');    //add or remove class .beat
            heartbeat();                      //and call the function again
        },500);                               //every half second
    }
    heartbeat();                              //CPR - start the heartbeat
});

答案 3 :(得分:0)

您可以使用动画效果进行模拟听力节拍。

$.extend($.easing, {
  heartBeat: function(k, time, start_value = 0, end_value = 1, duration) {
    if (k < 0.3) return Math.pow(k, 4) * 49.4;
    else if (k < 0.4) return (9 * k) - 2.3;
    else if (k < 0.5) return (-13 * k) + 6.5;
    else if (k < 0.6) return (4 * k) - 2;
    else if (k < 0.7) return 0.4;
    else if (k < 0.75) return (4 * k) - 2.4;
    else if (k < 0.8) return (-4 * k) + 3.6;
    else if (k >= 0.8) return 1 - Math.sin(Math.acos(k));
  },
  heartIn: function(k, time, start_value, end_value, duration) {
    return $.easing.heartBeat(k, time, start_value, end_value, duration);
  },
  heartOut: function(k, time, start_value, end_value, duration) {
    return end_value - $.easing.heartBeat(1 - k, time, start_value, end_value, duration) + start_value;
  },
  heartInOut: function(k, time, start_value, end_value, duration) {
    if (time < duration / 2) return $.easing.heartIn(k, time, start_value, end_value, duration);
    return $.easing.heartOut(k, time, start_value, end_value, duration);
  },
});

function heartBeat($element, easing, sign = '+') {
  $element.animate({
    width: `${sign}=50`,
    height: `${sign}=50`,
  }, 2000, easing, function() {
    heartBeat($element, easing, sign === '+' ? '-' : '+');
  });
}

heartBeat($('#img1'), 'heartIn');
heartBeat($('#img2'), 'heartOut');
heartBeat($('#img3'), 'heartInOut');
div img {
  content: url('');
  display: block;
  width: 75px;
  height: 75px;
  margin: 0 auto;
}

div div {
  width: 30%;
  padding: 10px 50px;
  margin: 0 auto;
}
<script src="http://code.jquery.com/jquery-3.1.1.min.js" integrity="sha256-hVVnYaiADRTO2PzUGmuLJr8BLUSjGIZsDYGmIJLv2b8=" crossorigin="anonymous"></script>
<script src="http://code.jquery.com/ui/1.12.1/jquery-ui.min.js" integrity="sha256-VazP97ZCwtekAsvgPBSUwPFKdrwD3unUfSGVYrahUqU=" crossorigin="anonymous"></script>


<div>
  <div>
    <img src="" id="img1">
  </div>
  <div>
    <img src="" id="img2">
  </div>
  <div>
    <img src="" id="img3">
  </div>
</div>

结果(静态屏幕)。运行代码,你会看到动画。

enter image description here