Company logo
  • Jobs
  • Bootcamp
  • About Us
  • For professionals
    • Home
    • Jobs
    • Courses
    • Questions
    • Teachers
    • Bootcamp
  • For business
    • Home
    • Our process
    • Plans
    • Assessments
    • Payroll
    • Blog
    • Calculator

0

78
Views
How can I show a heading element on button click?

I am using keyframes but my h1 is not visible on button click. What am I doing wrong?

Here is my code:

function abc() {
  document.querySelector('.h1cls').classList.add('fadeIn')
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.fadeIn {
  animation-name: fadeIn;
  animation-duration: 150ms;
  animation-timing-function: linear;
  animation-delay: 5000ms;
  /*opacity:1;*/
}

.one .two .h1cls {
  opacity: 0;
}
<div class="one">
  <div class="two">
    <h1 class="h1cls">hello</h1>
    <div></div>
  </div>
</div>

<button onclick="abc()">asd</button>

https://codesandbox.io/s/serene-lamport-12kgz?file=/index.html:0-994

actually I am using opacity . I am setting opacity to 1 after button click.

7 months ago · Juan Pablo Isaza
3 answers
Answer question

0

In your abc() function, you should also remove h1cls class due to the fact that it still applies opacity: 0 style.

 function abc(){
    document.querySelector('.h1cls').classList.add('fadeIn')
    document.querySelector('.h1cls').classList.remove('h1cls')
 }
7 months ago · Juan Pablo Isaza Report

0

It is animating but then disappearing immediately. You need to tell the system to keep the final state of the animation. You do this with animation-fill-mode: forwards

Note that the animation will only run on the first click of the button.

7 months ago · Juan Pablo Isaza Report

0

You have to add animation-fill-mode:forwards; property too in the fadeClass in order to make this work

function abc() {
  document.querySelector('.h1cls').classList.add('fadeIn')
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.fadeIn {
  animation-name: fadeIn;
  animation-duration: 150ms;
  animation-timing-function: linear;
  /*animation-delay: 5000ms;*/
  animation-fill-mode:forwards; // add this line
  /*opacity:1;*/
}

.one .two .h1cls {
  opacity: 0;
}
<div class="one">
  <div class="two">

    <h1 class="h1cls">hello</h1>
    <div></div>

    <button onclick="abc()">asd</button>

7 months ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post job Plans Our process Sales
Legal
Terms and conditions Privacy policy
© 2023 PeakU Inc. All Rights Reserved.