+++ title = "transitions II - javascript" date = 2020-04-13 tags = ["html"] # layout: code +++ On veut maintenant déplacer un div dans un autre avec une transition sur le déplacement. Ppur ça, on va dans l'ordre : - récupérer les coordonnées de départ par rapport à la racine du document - arracher l'élément et le mettre dans le conteneur d'arrivée - le basculer en position relative et lui passer les coodonnées de départ - déclencher le déplacement jusqu'à sa position dans le conteneur d'arrivée {% highlight js linenos %} function move_into(el, destEl) { let startPos = el.getBoundingClientRect(); console.log('start point', startPos.left, startPos.top); destEl.appendChild(el); let endPos = el.getBoundingClientRect(); console.log("way to go", endPos.left-startPos.left, endPos.top-startPos.top); // We are in final position, we need to move back to inital pos. el.style.position = "relative"; el.style.left = startPos.left - endPos.left + "px"; el.style.top = startPos.top - endPos.top + "px"; el.style.transition = "all 1s"; // Let javascript notice current state : void el.offsetLeft; // Trigger transition : move to final position. el.style.left = "0"; el.style.top = "0"; } {% endhighlight %} Si vous lisez l'anglais, ce qu'on vient de voir devrait être assez lisible. Le plus obscur est certainement l'utilisation de `void`. Ligne 16, On utilise la commande {% highlight js %} void el.offsetLeft; {% endhighlight %} pour obliger javascript à constater l'état de départ, avant de rentrer les coordonnées d'arrivée. En effet, sinon javascript ne voit pas le changement de valeur des coordonnées, il ne voit que la valeur finale. Et dans ce cas, pas d'animation de la transition, on va directement aux valeurs finales. Voilà le fragment de html et sa prévisualisation : ``` html
texte dans la cible
un div pour prendre un peu de place
texte dans la flèche
``` Je dois dire que je trouve assez frustrant de ne pas pouvoir déclencher les transitions sur les éléments impactés. J'ai essayé, je n'ai rien trouvé de concluant. [la suite]({{< relref transition-3 >}})