Le routage est une technique que vous utiliserez avec de nombreux frameworks, y compris Svelte. Découvrez comment l'utiliser à votre avantage.
Svelte est un framework Web à croissance rapide que vous pouvez utiliser pour créer des sites Web. Il se présente comme une alternative légère et facile à utiliser aux frameworks populaires tels que React et Vue.
Chaque framework JavaScript populaire possède une bibliothèque associée que vous pouvez utiliser pour le routage. Découvrez comment Svelte vous permet de gérer vos URL et le code qui les gère.
Bibliothèques de routage populaires
La bibliothèque de routage la plus populaire pour React est React Router, créé par l'équipe Remix. Pour VueJS, il y a Vue Router qui donne au développeur un contrôle précis sur toute navigation. Dans le monde Svelte, la bibliothèque de routage la plus populaire est routage svelte.
L'autre bibliothèque de routage principale pour Svelte est navigateur svelte. Comme c'est une fourchette de routage svelte, il est utile de se renseigner d'abord sur cette bibliothèque.
Fonctionnement de la bibliothèque de routage svelte
Il existe trois composants importants pour la gestion des itinéraires dans Svelte: Routeur, Lien, et Itinéraire. Pour les utiliser dans votre application, il vous suffit d'importer ces utilitaires depuis le routage svelte bibliothèque.
<scénario>
importer {Route, Router, Link} à partir de "svelte-routing" ;
scénario>
Le composant Router peut avoir deux accessoires facultatifs: chemin de base et URL. Le chemin de base la propriété est similaire à la nom de base prop dans React Router.
Par défaut, il est défini sur "/". basepath peut être utile si votre application a plusieurs points d'entrée. Par exemple, considérez le code Svelte suivant :
<scénario>
import { Route, Router, Link } de "svelte-routing" ;
let basepath = "/user" ;
let path = location.pathname;
scénario><Routeur {chemin de base}>
<divsur clic={() => (chemin = emplacement.nom du chemin)}>
<Lienpour="/">Aller à la maisonLien>
<Lienpour="/utilisateur/david">Connectez-vous en tant que DavidLien>
div><principal>
Tu es là: <code>{chemin}code><Itinérairechemin="/">
<h1>Bienvenue à la maison!h1>
Itinéraire>
<Itinérairechemin="/David">
<h1>Bonjour David!h1>
Itinéraire>
principal>
Routeur>
Si vous exécutez ce code, vous remarquerez que lorsque vous cliquez sur le Aller à la maison bouton, le navigateur navigue vers le chemin de base "/user". Route définit le composant qui doit être rendu si le chemin correspond à la valeur dans le spécifié Itinéraire soutenir.
Vous pouvez définir les éléments à rendre à l'intérieur du composant Route ou en tant que .svelte fichier tant que vous importez ce fichier correctement. Par exemple:
<Itinérairechemin="/à propos de"composant={À propos de}/>
Le bloc de code ci-dessus indique au navigateur de rendre le Application composant lorsque le nom du chemin est "/about".
Lors de l'utilisation routage svelte, définir des liens internes avec le Lien composant au lieu du HTML traditionnel un éléments.
Ceci est similaire à la façon dont React Router gère les liens internes; chaque composant Link doit avoir un pour prop qui indique au navigateur vers quel chemin naviguer.
Lorsque le navigateur affiche un composant Svelte, Svelte convertit automatiquement tous les composants Link en composants équivalents. un éléments, remplaçant les pour étai avec un href attribut. Cela signifie que lorsque vous écrivez ce qui suit :
<Lienpour="/un/chemin">Il s'agit d'un composant de lien dans le routage svelteLien>
Svelte le présente au navigateur comme :
<unhref="/un/chemin">Il s'agit d'un composant de lien dans le routage svelteun>
Vous devez utiliser le composant Link au lieu du traditionnel un élément lorsque vous travaillez avec un routage svelte. Ceci est dû au fait un les éléments effectuent un rechargement de page par défaut.
Créer un SPA avec Svelte et Svelte-Routing
Il est temps de mettre en pratique tout ce que vous avez appris en créant une application de dictionnaire simple qui permet à l'utilisateur de rechercher des mots. Ce projet utilisera la version gratuite API de dictionnaire.
Pour commencer, assurez-vous que Yarn est installé sur votre machine et exécutez :
fil créer vite
Cela échafaudera un nouveau projet en utilisant l'outil de construction Vite. Nommez votre projet puis choisissez "Svelte" comme framework et "JavaScript" comme variante. Après cela, exécutez les commandes suivantes l'une après l'autre :
CD
fil
fil ajouter svelte-routage
dev de fil
Ensuite, supprimez le contenu du App.svelte fichier et modifiez la structure du projet pour qu'elle ressemble à ceci :
Sur l'illustration ci-dessus, vous pouvez voir qu'il existe un dossier "components" avec deux fichiers: Accueil.svelte et Signification.svelte. Signification.svelte est le composant qui s'affichera lorsque l'utilisateur recherche un mot.
Naviguez vers le App.svelte et importez les composants Route, Router et Link à partir de la bibliothèque svelte-routing. Assurez-vous également d'importer le Accueil.svelte et App.svelte Composants.
<scénario>
import { Route, Router, Link } de "svelte-routing" ;
importer Home depuis "./components/Home.svelte" ;
importer la signification de "./components/Meaning.svelte" ;
scénario>
Ensuite, créez un composant Routeur qui encapsule un principal Élément HTML avec la classe "app".
<Routeur>
<principalclasse="application">
principal>
Routeur>
Dans le principal élément, ajoutez un navigation élément avec un composant Link comme enfant. La prop "to" de ce composant Link doit pointer vers "/". Ce composant permettra à l'utilisateur de naviguer vers la page d'accueil.
<principalclasse="application">
<navigation>
<Lienpour="/">MaisonLien>
navigation>
principal>
Il est maintenant temps de travailler sur les itinéraires. Lorsque l'utilisateur charge l'application, le Maison le composant doit rendre.
Naviguer vers "/find/:word" devrait rendre le Signification composant. La clause ":word" est un paramètre de chemin.
Pour ce projet, vous n'avez pas à vous soucier du CSS. Remplacez simplement le contenu de votre propre app.css fichier avec le contenu du app.css fichier de ce référentiel GitHub.
Il est maintenant temps de définir les itinéraires. Le chemin de niveau racine doit rendre le Maison composant, tandis que "/find/:word" devrait rendre le Signification composant.
<Itinérairechemin="/"composant={Maison} />
<Itinérairechemin="/trouver/:mot"let: paramètres>
<Significationmot={params.word} />
Itinéraire>
Ce bloc de code utilise le laisser directive pour transmettre le paramètre "mot" à la Signification composant comme accessoire.
Maintenant, ouvrez le Accueil.svelte fichier et importer le naviguer utilitaire de la bibliothèque "svelte-routing" et définir une variable mot saisi.
<scénario>
importer {naviguer} à partir de "svelte-routing" ;
laissez enterWord ;
scénario>
Sous le scénario tag, créez un élément principal avec la classe "homepage", puis créez un div élément avec la classe "dictionary-text".
<principalclasse="page d'accueil">
<divclasse="dictionnaire-texte">Dictionnairediv>
principal>
Ensuite, créez un formulaire avec un sur: soumettre directif. Ce formulaire doit contenir deux enfants: un saisir élément dont la valeur est liée à mot saisi variable et un bouton d'envoi qui est rendu conditionnellement dès que l'utilisateur commence à taper :
<formersur: soumettre|preventDefault={() => naviguer(`/find/${enteredWord.toLowerCase()}`)}>
<saisir
type="texte"
lier: valeur={mot saisi}
placeholder="Commencez votre recherche..."
mise au point automatique
/>
{#si mot saisi}
<boutontaper="soumettre">Mot de recherchebouton>
{/si}
former>
Ce bloc de code utilise le naviguer fonction pour rediriger l'utilisateur une fois l'action de soumission terminée. Maintenant, ouvrez le Signification.svelte fichier et, dans la balise script, exportez le mot soutenir et créer un Message d'erreur variable:
export let word;
laissez errorMessage = "Aucune connexion. Vérifiez votre internet" ;
Ensuite, faites une requête GET à l'API Dictionary en transmettant le mot comme paramètre :
asynchronefonctiongetWordMeaning(mot) {
constante réponse = attendre aller chercher(
` https://api.dictionaryapi.dev/api/v2/entries/en/${mot}`
);constante json = attendre réponse.json();
console.log (json);si (réponse.ok) {
retour json;
} autre {
errorMessage = json.message;
lancernouveauErreur(json);
}
}
laisser promesse = getWordMeaning (mot);
Dans le bloc de code ci-dessus, la fonction asynchrone renvoie les données JSON si la réponse aboutit. La variable promise représente le résultat de la getWordMeaning fonction lorsqu'elle est invoquée.
Dans le balisage, définissez un div avec la classe sens-page. Ensuite, définissez un élément h1 qui contient le mot variable en minuscule :
<divclasse="page de sens">
<h1>
{word.toLowerCase()}
h1>
div>
Ensuite, utilisez les blocs await de Svelte pour appeler le getWordMeaning fonction:
{#attendre la promesse}
<p>Chargement...p>
{:then entrées}
{:attraper}
{Message d'erreur}
{/attendre}
Ce code affiche le Chargement... texte quand la requête GET est faite à l'API. S'il y a une erreur, il affichera le contenu de Message d'erreur.
Dans le {:then entrées} bloc, ajoutez ce qui suit :
{#each entrées comme entrée}
{#chaque entrée.significations comme signification}
<divclasse="entrée">
<divclasse="partie du discours">
{signification.partOfSpeech}
div><ol>
{#chaque signification.définitions comme définition}
<li>
{définition.définition}
<Br />
<divclasse="exemple">
{#if definition.example}
{définition.exemple}
{/si}
div>
li>
{/chaque}
ol>
div>
{/chaque}
{/chaque}
Si la promesse se résout avec succès, le entrées variable contient les données résultantes.
Alors pour chaque itération de entrée et signification, ce code rend la partie du discours en utilisant sens.partOfSpeech et une liste de définitions utilisant définition.définition. Il rendra également un exemple de phrase, s'il y en a un de disponible.
C'est ça. Vous avez créé une application de page unique de dictionnaire (SPA) à l'aide de svelte-routing. Vous pouvez aller plus loin si vous le souhaitez, ou vous pouvez vérifier navigateur svelte, une fourchette de routage svelte.
Améliorer l'expérience utilisateur avec le routage côté client
La gestion du routage dans le navigateur au lieu du serveur présente de nombreux avantages. Les applications qui utilisent le routage côté client peuvent sembler plus fluides pour l'utilisateur final, en particulier lorsqu'elles sont associées à des animations et des transitions.
Cependant, si vous souhaitez que votre site Web soit mieux classé dans les moteurs de recherche, vous devez envisager de gérer les itinéraires sur le serveur.