JavaScript DOM Animate


Obsah

    Zobrazit obsah


Naučte se vytvářet HTML animace pomocí JavaScriptu.


Základní webová stránka

Abychom demonstrovali, jak vytvořit HTML animace pomocí JavaScriptu, použijeme jednoduchý webová stránka:

Příklad

<!DOCTYPE html>
<html>
<body>
<h1>My First 
 JavaScript Animation</h1>

<div id="animation">My animation will go here</div>

</body>
</html>

Vytvořte animační kontejner

Všechny animace by měly být relativní k prvku kontejneru.

Příklad

<div id ="container">
  <div id ="animate">My 
 animation will go here</div>
</div>

Upravte styl prvků

Prvek kontejneru by měl být vytvořen stylem="position: relativní".

Prvek animace by měl být vytvořen stylem="position: absolute".

Příklad

#container {
  width: 400px;
  height: 
 400px;
  position: relative;
  
 background: yellow;
 }
#animate {
  width: 50px;
  height: 
 50px;
  position: absolute;
  
 background: red;
}

Zkuste to sami →

<!Doctype html>
<html>
<style>
#container {
  width: 400px;
  height: 400px;
  position: relative;
  background: yellow;
}
#animate {
  width: 50px;
  height: 50px;
  position: absolute;
  background: red;
}
</style>
<body>

<h2>My First JavaScript Animation</h2>

<div id="container">
<div id="animate"></div>
</div>

</body>
</html>


Animační kód

Animace JavaScriptu se provádějí programováním postupných změn v prvku styl.

Změny jsou vyvolány časovačem. Když je interval časovače malý, animace vypadá kontinuálně.

Základní kód je:

Příklad

id = setInterval(frame, 5);
function frame() {
  if (/* 
 test for finished */) {
    clearInterval(id);
  } else {
      
 /* code to change the element style */  
  }
}

Vytvořte úplnou animaci pomocí JavaScriptu

Příklad

function myMove() {
  let id = null;
  const elem = document.getElementById("animate");
  let pos = 0;
  
  clearInterval(id);
  id = setInterval(frame, 5);
  
 function frame() {
    if (pos == 
 350) {
      
 clearInterval(id);
    } else {
      
 pos++; 
      elem.style.top = pos + 'px'; 
      elem.style.left = pos + 'px'; 
      }
  }
}

Zkuste to sami →

<!DOCTYPE html>
<html>
<style>
#container {
  width: 400px;
  height: 400px;
  position: relative;
  background: yellow;
}
#animate {
  width: 50px;
  height: 50px;
  position: absolute;
  background-color: red;
}
</style>
<body>

<p><button onclick="myMove()">Click Me</button></p> 

<div id ="container">
  <div id ="animate"></div>
</div>

<script>
function myMove() {
  let id = null;
  const elem = document.getElementById("animate");   
  let pos = 0;
  clearInterval(id);
  id = setInterval(frame, 5);
  function frame() {
    if (pos == 350) {
      clearInterval(id);
    } else {
      pos++; 
      elem.style.top = pos + "px"; 
      elem.style.left = pos + "px"; 
    }
  }
}
</script>

</body>
</html>