Maison >interface Web >js tutoriel >Introduction détaillée à l'implémentation d'animations JavaScript
De nos jours, de nombreuses pages ont des effets d'animation. Des effets d'animation appropriés peuvent améliorer la beauté de la page dans une certaine mesure, et des animations avec des effets d'invite peuvent améliorer la convivialité de la page.
Il existe deux manières d'implémenter l'animation de page. L'une consiste à exploiter indirectement les styles CSS en exécutant JavaScript et à mettre à jour à chaque période de temps ; l'autre consiste à définir l'animation directement via CSS. La deuxième méthode a été largement adoptée après la maturation de CSS3. Dans cet article, nous discutons des principes et de la mise en œuvre de la première méthode.
Principe de mise en œuvre de l'animation JavaScriptTout d'abord, nous devons connaître deux concepts importants, le processus de temps d'animation et le processus d'effet d'animation. Le processus temporel d'animation fait référence à l'achèvement de l'animation en termes de temps, qui est un nombre compris entre [0, 1]. Supposons que l'animation commence à horodatage et se termine à t1
, et que l'horodatage actuel est t2
, alors la progression temporelle actuelle de l'animation est t
. Si vous ne parvenez pas à le comprendre, je vous suggère de le dessiner avec un stylo et du papier. Comprendre ce concept est crucial pour comprendre cet article. (t-t1)/(t2-t1)
valeur animé. Supposons que nous souhaitions modifier l'attribut CSS <a href="http://www.php.cn/wiki/907.html" target="_blank">left</a>
du L'élément de #el
est remplacé par <a href="http://www.php.cn/wiki/907.html" target="_blank">left</a>
, et actuellement il est devenu 100px
, donc le processus d'effet actuel de l'animation est 200px
. 130px
130px - 100px = 30px
Supposons que le processus de temps d'animation et le processus d'effet d'animation soient linéaires. Donc, si vous connaissez le processus de temps d'animation, vous pouvez certainement obtenir le processus d'effet d'animation.
Selon cette explication, on peut programmer rapidement une animation linéaire.
JSBin(function() { var begin, // 开始动画的时间 el, start, end, duration; var INTERVAL = 13; function now() { return (new Date).getTime(); } /** * 执行一步动画(更新属性) */ function _animLeft() { var pos = (now() - begin) / duration; if (pos >= 1.0) { return false; } return !!(el.style.left = start + (end - start) * pos); } /** * 对一个DOM执行动画,left从_start到_end,执行时间为 * _duration毫秒。 * * @param {object} _el 要执行动画的DOM节点 * @param {integer} _start left的起始值 * @param {integer} _end left的最终值 * @param {integer} _duration 动画执行时间 */ function animLeft(_el, _start, _end, _duration) { stopped = false; begin = now(); el = _el; start = _start; end = _end; duration = _duration || 1000; var step = function() { if (_animLeft()) { setTimeout(step, INTERVAL); } }; setTimeout(step, 0); } window.animLeft = animLeft; })(); animLeft( document.getElementById('el'), 100, 200 )
easing
Comme mentionné ci-dessus, nous savons que contrôler le processus temporel de l'animation équivaut à contrôler le processus d'effet de l'animation. Au fur et à mesure que le temps avance dans le monde réel, la progression temporelle de l'animation suivra, contrôlant ainsi la progression des effets de l'animation. Ensuite, nous pouvons contrôler le processus d'animation en modifiant la relation de mappage entre le processus temporel du monde réel et le processus temporel d'animation. Si vous êtes confus, cela n'a pas d'importance, veuillez jeter un œil à l'image ci-dessous :
Il s'agit de la relation cartographique entre le processus temporel du monde réel et l'animation processus en animation linéaire. Ensuite, on la transforme
Cette courbe est en fait l'image de la
fonctionLorsque l'heure du monde réel atteint
, le processus d'animation devrait initialement se dérouler jusqu'à, mais après la transformation, il ne passe qu'à x0
. En fin de compte, tous les fleuves retournent à la mer et les deux lignes se rejoignent au point (1, 1). Ici, y0
est la y1
fonction d'assouplissement y = x * x
. Modifions l'exemple ci-dessus pour rendre l'animation non linéaire.
function ease(time) { return time * time; } /** * 执行一步动画(更新属性) */ function _animLeft() { var pos = (now() - begin) / duration; if (pos >= 1.0) { return false; } pos = ease(pos); return !!(el.style.left = (start + (end - start) * pos) + "px"); }
On peut voir une telle fonction dans le code de
jQuery Par conséquent, vous pouvez ajouter la fonction d'assouplissement à jQuery.easing pour que jQuery prenne en charge la nouvelle méthode de contrôle du taux d'animation. Notez que le domaine et la plage de valeurs de la fonction d'assouplissement doivent être [0, 1].jQuery.easing = { linear: function( p ) { return p; }, swing: function( p ) { return 0.5 - Math.cos( p * Math.PI ) / 2; } };Résumé
jQuery.easing.myEasing = function( p ) { return ... }
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!