Maison  >  Article  >  interface Web  >  Méthode d'implémentation du mouvement du tampon JavaScript (2 exemples)_compétences Javascript

Méthode d'implémentation du mouvement du tampon JavaScript (2 exemples)_compétences Javascript

WBOY
WBOYoriginal
2016-05-16 15:21:071185parcourir

L'exemple de cet article décrit la méthode d'implémentation du mouvement du tampon JavaScript. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :

Principe de mise en œuvre : (distance cible - distance actuelle) / base = vitesse (plus la distance est grande, plus la vitesse est petite, et la distance et la vitesse sont inversement proportionnelles)

Copier le code Le code est le suivant :
(500 - oDiv.offsetLeft) / 7 = iSpeed;

Remarque : : Lorsque la vitesse calculée contient des décimales, elle doit être arrondie
;

Copier le code Le code est le suivant :
(500 - oDiv.offsetLeft) / 7 = iSpeed ​​​​; = iSpeed>0 ? Math.ceil(iSpeed):Math.floor(iSpeed);

Exemple 1 : Mouvement du tampon du curseur

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>缓冲运动</title>
<style>
#div1{ width:100px; height:100px; background:red; position:absolute; top:50px; left:0;}
span{ width:1px; height:300px; background:black; position:absolute; left:300px; top:0; display:block;}
</style>
<script>
window.onload = function()
{
 var oBtn = document.getElementById('btn1');
 var oDiv = document.getElementById('div1');
 oBtn.onclick = function()
 {
  startMove(oDiv, 300);
 };
};
var timer = null;
function startMove(obj, iTarget)
{
 clearInterval(timer);
 timer = setInterval(function(){
  var iSpeed = (iTarget - obj.offsetLeft)/8;
  iSpeed = iSpeed>0&#63;Math.ceil(iSpeed):Math.floor(iSpeed);
  if(iTarget==obj.offsetLeft){
   clearInterval(timer);
  }else{
   obj.style.left = obj.offsetLeft + iSpeed + 'px';
  }
 }, 30);
}
</script>
</head>
<body>
<input id="btn1" type="button" value="移动" />
<div id="div1"></div>
<span></span>
</body>
</html>

Exemple 2 : Déplacement de la barre latérale

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>侧边栏滑动</title>
<style>
#div1{ width:100px; height:100px; background:red; position:absolute; right:0; top:0;}
</style>
<script>
window.onload = window.onscroll = function()
{
 var oDiv = document.getElementById('div1');
 var iScrollTop = document.documentElement.scrollTop || document.body.scrollTop;
 var clientHeight = document.documentElement.clientHeight;
 var iH = (clientHeight - oDiv.offsetHeight)/2 + iScrollTop;
 //oDiv.style.top = iH + 'px';
 startMove(oDiv, parseInt(iH));
};
var timer = null;
function startMove(obj, iTarget)
{
 clearInterval(timer);
 timer = setInterval(function(){
  var iSpeed = (iTarget - obj.offsetTop) / 8;
  iSpeed = iSpeed>0&#63;Math.ceil(iSpeed):Math.floor(iSpeed);
  if(obj.offsetTop == iTarget){
   clearInterval(timer);
  }else{
   obj.style.top = obj.offsetTop + iSpeed + 'px';
  }
 }, 30);
}
</script>
</head>
<body style="height:2000px;">
<div id="div1"></div>
</body>
</html>

Pour plus de contenu lié aux effets de mouvement JavaScript, veuillez consulter le sujet spécial sur ce site : "Résumé des effets et techniques de mouvement JavaScript"

J'espère que cet article sera utile à tout le monde dans la programmation JavaScript.

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn