I want to make the heart icon move up, turn red, move back down, and turn back to black when I click on it. I also want to keep track of how many times I've clicked on it.
我想让心形图标向上移动,变成红色,然后向下移动,当我点击它时,它又变回黑色。我还想记录一下我点击了多少次。
My html
我的html
<div class="center">
<i class="fa-regular fa-heart" onclick="heartAnimation()"></i>
<p id="count">0</p>
</div>;
My css
我的css
@keyframes heart {
40% {
transform: translateY(-10px);
color: red;
}
95% {
transform: translateY(0px;);
color: red;
}
100% {
color: black;
}
}
.animation {
animation: heart 1s;
}
My Javascript
我的Java脚本
const icon = document.querySelector(".fa-regular");
const count = document.querySelector("#count");
count = 0;
function heartAnimation() {
icon.classList.add("animation");
count.innerText++;
}
I originally thought that I could add an onclick listener to the icon and add a class that would call the keyframe and keep count of the clicks. The click counter works fine, but I want it so that the animation is called every time that I click it. Right now, it moves up and down only on the first click. After that, the heart icon doesn't move or change color - only the click counter changes.
我原本以为可以向图标添加一个onClick侦听器,并添加一个调用关键帧并计算点击次数的类。点击计数器工作得很好,但我想要它,以便每次我单击它时都会调用动画。现在,它只在第一次点击时上下移动。在此之后,心形图标不会移动或改变颜色--只有点击计数器会改变。
更多回答
You need to remove the class at the end of animation. Since you know the animation is 1 second you can simply remove the class using a setTimeout()
(maybe remove it after 1.1 second to let the animation to complete)
您需要在动画结束时删除该类。因为您知道动画是1秒,所以只需使用setTimeout()删除类(可能在1.1秒后删除它,让动画完成)
优秀答案推荐
you can do this through adding and removing animation class at the desired time.
您可以通过在所需时间添加和移除动画类来完成此操作。
to do this you can use jquery code:
为此,您可以使用jQuery代码:
$("someElement").addClass("className")
$("someElement").removeClass("className")
or javascript (vanilla/pure):
或javascript(普通/纯):
document.getElementById("someElementID").classList.add("className")
document.getElementById("someElementID").classList.remove("className")
also if you need special times for your animation to kick in or to be removed you need to use events and functions like scroll height, timeout, interval, onclick, .etc
此外,如果您的动画需要特殊时间才能生效或删除,则需要使用滚动高度、超时、间隔、onClick等事件和函数
Couple of things:
几件事:
- You assign count as a constant for the first node in the node list that returns an id of count. Then you redefine it as
0
and try to increment it later in your function.
- use a number
let num = 0;
for the incrementing and then assign the number to the nodes textContent once you increment it from its previous value.
- As a commentor said you can use a setTimeout to correspond with the timing of your animation. Inside the timeout remove your animation class.
setTimeout(()=>{
icon.classList.remove("animation");
},1000)
Optionally you could also add a pointer-event in the CSS to remove any clicks while the animation is playing. You could also code in logic that would store the click and reset the animation on click.
或者,您也可以在css中添加一个指针事件,以在播放动画时移除任何点击。您还可以编写逻辑代码来存储点击并在点击时重置动画。
Lastly I prefer adding event listeners using .addEventListener
method.
最后,我更喜欢使用.addEventListener方法添加事件侦听器。
Some important notes about .addEventListener
vs onclick=
from (MDN)
关于.addEventListener与onClick=from(MDN)的一些重要注意事项
- It allows adding more than one handler for an event. This is particularly useful for libraries, JavaScript modules, or any other kind of code that needs to work well with other libraries or extensions.
- In contrast to using an onXYZ property, it gives you finer-grained control of the phase when the listener is activated (capturing vs. bubbling).
- It works on any event target, not just HTML or SVG elements.
const icon = document.querySelector(".fa-regular");
let count = document.querySelector("#count");
let num = 0;
function heartAnimation() {
icon.classList.add("animation");
num++;
count.textContent = num;
setTimeout(() => icon.classList.remove("animation"), 1000);
}
icon.addEventListener('click', heartAnimation);
.animation {
animation: heart 1s;
/* runs a bit smoother is we let the animtation play out before allowing user to click again. Set pointer-events to none you can remove the pointer-events if you want to allow users to click before the animation ends */
pointer-events: none;
}
@keyframes heart {
40% {
transform: translateY(-10px);
color: red;
}
95% {
transform: translateY(0px;);
color: red;
}
100% {
color: black;
}
}
<link href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.2/css/all.min.css" rel="stylesheet"/>
<div class="center">
<i class="fa-regular fa-heart"></i>
<p id="count">0</p>
</div>;
更多回答
我是一名优秀的程序员,十分优秀!