Bases de Svelte
Introduction
Liaisons
Classes et styles
Svelte avancé
Réutiliser du contenu
Mouvements
Liaisons avancées
Transitions avancées
API de contexte
Éléments spéciaux
<script module>
Next steps
Bases de SvelteKit
Introduction
Routing
Chargement de données
En-têtes et cookies
Modules partagés
Formulaires
$app/state
Erreurs et redirections
SvelteKit avancé
Options de page
Options de lien
Routing avancé
Chargement avancé
Variables d’environnement
Conclusion
Les blocs #key détruisent et reconstruisent leur contenu lorsque la valeur d’une expression
change. Ceci sert si vous souhaitez qu’un élément joue sa transition à chaque fois qu’une valeur
change plutôt qu’uniquement lorsqu’un élément entre ou sort du DOM.
Ici par exemple, nous voulons jouer la transition typewriter définie dans transition.js à chaque
fois que le message de chargement, c-à-d i, change. Entourez l’élément <p> dans un bloc #key :
App
{#key i}
<p in:typewriter={{ speed: 10 }}>
{messages[i] || ''}
</p>
{/key}Modifier cette page sur Github
précédent suivant
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<script>
import { typewriter } from './transition.js'; import { messages } from './loading-messages.js';let i = $state(-1);
$effect(() => { const interval = setInterval(() => {i += 1;
i %= messages.length;
}, 2500);
return () => {clearInterval(interval);
};
});
</script>
<h1>chargement...</h1>
<p in:typewriter={{ speed: 10 }}> {messages[i] || ''}</p>