Maison > interface Web > js tutoriel > Mouvement de chaîne en JS (tutoriel détaillé)

Mouvement de chaîne en JS (tutoriel détaillé)

亚连
Libérer: 2018-06-09 16:15:39
original
1578 Les gens l'ont consulté

Cet article présente principalement le mouvement en chaîne des effets spéciaux de mouvement JS, et analyse les principes et les techniques spécifiques de mise en œuvre du mouvement en chaîne javascript sous forme d'exemples. Les amis dans le besoin peuvent s'y référer

Les exemples de. cet article décrit le mouvement JS Chain des effets spéciaux de mouvement. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :

Suivez l'article précédent "Méthodes pour ajouter du mouvement avec n'importe quelle valeur dans les effets spéciaux JS Motion" et continuez à lancer

Chain Motion : Un mouvement après l'autre. Par exemple : lorsque la souris est déplacée sur p, la largeur sera d'abord agrandie, puis la hauteur sera agrandie, puis la transparence sera modifiée, etc. Une série de mouvements sont effectués successivement. Sans plus attendre, passons aux châtaignes ! !

Lorsque la souris se déplace vers p, p devient d'abord plus large, puis devient plus grand, puis change de transparence lorsqu'il est déplacé, il revient à son état d'origine ; par un;

Mise en œuvre la chaîne Pour le mouvement, nous devons continuer à améliorer la fonction startMove() de l'article précédent

function startMove(obj,attr,iTarget,fn) et en passer une de plus Paramètre fn pour indiquer quand un mouvement se termine. Après cela, passez au mouvement suivant. Bien sûr, besoin de juger S'il y a un prochain mouvement, effectuez. le mouvement suivant. Sinon, continuez à effectuer le mouvement suivant

if(fn){
  fn();
}
Copier après la connexion

Code de test complet :

Partie HTML :

<body>
<p id="p1"></p>
</body>
Copier après la connexion

Partie css :

<style>
  #p1{
   width: 200px;height: 200px;
   background: green;
  }
</style>
Copier après la connexion

partie js :

<script>
  window.onload = function(){
   var op = document.getElementById(&#39;p1&#39;);
   op.onmouseover = function () {
    startMove(op,&#39;width&#39;,300,function () {
     startMove(op,&#39;height&#39;,300, function () {
      startMove(op,&#39;opacity&#39;,30);
     });
    });
   }
   op.onmouseout = function () {
    startMove(op,&#39;opacity&#39;,100, function () {
     startMove(op,&#39;height&#39;,200, function () {
      startMove(op,&#39;width&#39;,200);
     });
    });
   }
  }
  function getStyle(obj,attr){
   return getComputedStyle ? getComputedStyle(obj,false)[attr] : obj.currentStyle[attr];
  }
  function startMove(obj,attr,iTarget,fn) {//fn:执行下一个运动的函数
   clearInterval(obj.timer);
   obj.timer = setInterval(function () {
    var objAttr = 0;
    if(attr == "opacity"){
     objAttr = Math.round(parseFloat(getStyle(obj,attr))*100);
    }else{
     objAttr = parseInt(getStyle(obj,attr));
    }
    var iSpeed = (iTarget -objAttr)/10;
    iSpeed = iSpeed>0 ?Math.ceil(iSpeed):Math.floor(iSpeed);
    if(objAttr == iTarget){
     clearInterval(obj.timer);
     if(fn){// 如果传了 “下一个运动的函数” 就执行
      fn();
     }
    }else{
     if(attr == "opacity"){
      obj.style.filter = &#39;alpha(opacity:&#39;+(objAttr+iSpeed)+&#39;)&#39;;
      obj.style.opacity = (objAttr+iSpeed)/100;
     }else{
      obj.style[attr] = objAttr+iSpeed+&#39;px&#39;;
     }
    }
   },30);
  }
</script>
Copier après la connexion

Ce qui précède est ce que j'ai compilé pour tout le monde. J'espère que cela sera utile à tout le monde à l'avenir.

Articles associés :

Problèmes inter-domaines de ProxyTable dans le projet vue-cli

Serveur de requêtes de builds express

Utilisez la fonction de découpage personnalisée de js pour supprimer les espaces aux deux extrémités

Principe d'exécution de JavaScript

Explication détaillée de l'utilisation de Jest pour tester le composant natif de réaction

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
js
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal