Animations Svelte et Spring
L'animation de printemps est un excellent moyen de donner vie aux interactions d'interface utilisateur. Au lieu de changer les propriétés à un rythme constant sur une période de temps, l'animation de printemps utilise la physique du printemps pour déplacer les choses, donnant aux gens l'impression que les objets réels se déplacent et offrent aux utilisateurs une expérience plus naturelle.
J'ai déjà écrit sur l'animation de printemps. Cet article est basé sur React et utilise React-Spring pour l'animation. Cet article explorera des idées similaires à Svelte.
Développeur CSS! Lorsque vous contrôlez les effets d'animation, vous pensez généralement à l'assouplissement. Vous pouvez considérer l'animation "printemps" comme une sous-catégorie d'assouplissement basée sur la physique réelle.
Svelte a en fait des ressorts intégrés dans le cadre sans aucune bibliothèque externe requise. Nous passerons en revue la première moitié de l'article précédent sur React-Spring. Mais après cela, nous fouillerons dans toute l'utilisation des ressorts à Svelte et laisserons la mise en œuvre réelle à un futur article. Bien que cela puisse sembler décevant, Svelte a des fonctionnalités uniques que l'on ne trouve pas dans React pour s'intégrer efficacement à ces primitives d'animation. Nous prendrons un certain temps pour en discuter.
Une autre chose à noter: certaines des démonstrations entrecoupées dans cet article peuvent sembler bizarres, car j'ai configuré les ressorts pour être "élastiques" pour produire un effet plus visible. Si vous avez utilisé un code de démonstration, assurez-vous de trouver la configuration de ressort qui vous convient.
Ceci est un excellent REPORT fait par Rich Harris pour présenter diverses configurations de printemps et leur comportement.
Démarrage rapide avec le stockage svelte
Avant de commencer, jetons un coup d'œil à Svelte Storage. Alors que les composants de Svelte sont entièrement capables de stocker et de mettre à jour l'état, Svelte a également le concept de stockage, vous permettant de stocker l'état en dehors du composant. Étant donné que l'API de printemps de Svelte utilise le stockage, nous couvrirons brièvement ses parties importantes ici.
Pour créer une instance de stockage, nous pouvons importer le type écrivative et le créer comme ceci:
import {writeable} de "svelte / store"; const Clicks = Writable (0);
La variable Clicks est un magasin avec une valeur de 0. Il existe deux façons de définir la nouvelle valeur stockée: les méthodes SET et UPDATE. Le premier reçoit la valeur à défaire pour stocker, tandis que le second reçoit une fonction de rappel qui accepte la valeur actuelle et renvoie la nouvelle valeur.
fonction incrément () { clics.update (val => val 1); } fonction setTo5 () { clics.set (5); }
Si vous ne pouvez pas réellement utiliser l'état, l'état est inutile. Pour ce faire, le magasin fournit une méthode d'abonnement qui vous permet de recevoir des notifications de nouvelles valeurs, mais lorsque vous l'utilisez dans le composant, vous pouvez préfixer le nom de stockage avec un caractère $, qui indique à Svelte non seulement d'afficher la valeur actuelle stockée, mais aussi de mettre à jour lorsqu'elle change. Par exemple:
<h1 id="Valeur-cliquez"> Valeur {$ cliquez}</h1> Incrément Réglé sur 5
Il s'agit d'un exemple complet de code de travail. Le stockage fournit de nombreuses autres fonctionnalités telles que le stockage dérivé (qui vous permet de relier le stockage ensemble), le stockage lisible et même la possibilité d'être averti lorsque le stockage est observé pour la première fois et n'a plus d'observateur. Mais aux fins de cet article, le code indiqué ci-dessus est tout ce à quoi nous devons faire attention. Veuillez vous référer à la documentation Svelte ou au didacticiel interactif pour plus d'informations.
Course accidenté du printemps
Préduisons rapidement le ressort et sa fonction. Nous examinerons une interface utilisateur simple qui modifie les aspects de rendu de certains éléments (opacité et transformations), puis examiner les changements d'animation.
Il s'agit d'un composant svelte minimal qui passe à un<div> Opacité et basculer vers un autre<code><div> Conversion de l'axe X (sans aucune animation).<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"><div style="opacity: {shown ? 1 : 0}"> Contenu à basculer</div>
<br>Basculer
<hr><div style="transform: translateX({moved}px)">Je suis une boîte.</div>
<br>Déplacez-le!</pre><div class="contentsignin">Copier après la connexion</div></div>
<p> Ces modifications s'appliquent immédiatement, alors voyons comment les animer. C'est là que le ressort entre en jeu. Dans Svelte, un ressort est un stockage sur lequel nous pouvons définir la valeur souhaitée, mais elle ne change pas immédiatement, mais stocke plutôt la valeur modifiée progressivement à l'aide de la physique du ressort. Nous pouvons ensuite lier notre interface utilisateur à cette valeur modifiée pour obtenir un bel effet d'animation. Voyons comment cela fonctionne réellement.</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"> import {printemps} de "svelte / motion";
const fadespring = printemps (1, {rigidité: 0,1, amortissement: 0,5});
const transformspring = printemps (0, {rigidité: 0,2, amortissement: 0,1});
const togglefade = () => fadespring.update (val => (val? 0: 1));
const toggleransform = () => transformSpring.update (val => (val? 0: 500));
const SnapTransform = () => transformspring.update (val => val, {hard: true});
<div style="opacity: {$fadeSpring}">Contenu à s'estomper</div>
<br>Faire basculer
<hr><div style="transform: translateX({$transformSpring}px)">Je suis une boîte.</div>
<br>Déplacez-le!
Se mettre en place</pre><div class="contentsignin">Copier après la connexion</div></div>
<p> Nous obtenons la fonction de ressort de Svelte et définissons différentes instances de ressort pour les animations d'opacité et de transformation. La configuration à ressort de conversion est délibérément définie pour être <em>très élastique</em> pour aider à montrer plus tard comment fermer temporairement l'animation à ressort et appliquer les modifications requises immédiatement (cela sera utile plus tard). À la fin du bloc de script se trouve le gestionnaire de clics utilisé pour définir les propriétés requises. Ensuite, dans HTML, nous lions directement la valeur modifiée à notre élément ... c'est tout! Il s'agit de l'animation de printemps de base à Svelte.</p>
<p> Le seul élément restant est la fonction SnapTransform, que nous définissons le ressort de conversion en sa valeur actuelle, mais passons également un objet en deuxième paramètre, où dur: vrai. Cela a pour effet d'appliquer les valeurs requises immédiatement sans aucune animation.</p>
<p> Cette démo et le reste des exemples de base que nous verrons dans cet article sont ici: [Le lien de démonstration doit être inséré ici]</p>
<p> ... (La pseudo-originalité du reste de l'article maintient le sens original inchangé et maintient la position et le format de l'image)</p>
</div>
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds











Je vois que Google Fonts a déployé un nouveau design (tweet). Comparé à la dernière grande refonte, cela semble beaucoup plus itératif. Je peux à peine faire la différence

Avez-vous déjà eu besoin d'un compte à rebours sur un projet? Pour quelque chose comme ça, il pourrait être naturel d'atteindre un plugin, mais c'est en fait beaucoup plus

Tout ce que vous avez toujours voulu savoir sur les attributs de données dans HTML, CSS et JavaScript.

Lorsque le nombre d'éléments n'est pas fixé, comment sélectionner le premier élément enfant du nom de classe spécifié via CSS. Lors du traitement de la structure HTML, vous rencontrez souvent différents éléments ...

Questions sur les zones de slash violet dans les dispositions flexibles Lorsque vous utilisez des dispositions flexibles, vous pouvez rencontrer des phénomènes déroutants, comme dans les outils du développeur (D ...

Au début d'un nouveau projet, la compilation SASS se produit en un clin d'œil. Cela se sent bien, surtout quand il est associé à BrowSersync, qui recharge

Le tartan est un chiffon à motifs qui est généralement associé à l'Écosse, en particulier leurs kilts à la mode. Sur tartanify.com, nous avons rassemblé plus de 5 000 tartan

Comment implémenter des fenêtres dans le développement frontal ...
