


Conception et mise en œuvre d'Ant Design Global App Tour pour les applications React.
Les visites d'utilisateurs sont une fonctionnalité d'utilisation inestimable pour les applications Web. Ils vous permettent d'intégrer efficacement les nouveaux utilisateurs, en leur fournissant des guides étape par étape pour les aider à comprendre le logiciel. Les visites peuvent également servir de référence rapide pour des tâches récurrentes ou des fonctionnalités avancées.
L'objectif : solution de visite multipage
Nous visons à créer une solution qui vous permet de créer une expérience d'intégration qui s'étend sur plusieurs pages dans l'application React. Voici à quoi ça ressemble :
Ant Design Tour : une solution locale
Ant Design fournit un composant Tour pour créer des guides interactifs. Cependant, il présente certaines limites :
- Il fonctionne localement au sein d'un seul composant.
- Il s'appuie fortement sur les références React, ce qui le rend moins flexible pour les applications s'étendant sur plusieurs pages.
Voici un exemple tiré de la documentation officielle qui démontre une implémentation locale de base :
import React, { useRef, useState } from 'react'; import { EllipsisOutlined } from '@ant-design/icons'; import { Button, Divider, Space, Tour } from 'antd'; const App = () => { const ref1 = useRef(null); const ref2 = useRef(null); const ref3 = useRef(null); const [open, setOpen] = useState(false); const steps = [ { title: 'Upload File', description: 'Put your files here.', target: () => ref1.current }, { title: 'Save', description: 'Save your changes.', target: () => ref2.current }, { title: 'Other Actions', description: 'Click to see other actions.', target: () => ref3.current }, ]; return ( <> <Button type="primary" onClick={() => setOpen(true)}>Begin Tour</Button> <Divider /> <Space> <Button ref={ref1}>Upload</Button> <Button ref={ref2} type="primary">Save</Button> <Button ref={ref3} icon={<EllipsisOutlined />} /> </Space> <Tour open={open} onClose={() => setOpen(false)} steps={steps} /> </> ); }; export default App;
Bien que cette implémentation fonctionne bien pour des pages uniques, elle ne suffit pas dans les scénarios où les visites s'étendent sur plusieurs pages de votre application React.
Voici comment nous mettons cela en œuvre :
Étapes préalables, app.jsx, routes.jsx, routesNames.js :
import { RouterProvider } from "react-router-dom"; import AppRouter from "./routes"; export default function App() { return <RouterProvider router={AppRouter} />; }
export const ROUTE_NAMES = { HOME: "/", ABOUT: "/about", };
import AppLayout from "./AppLayout"; import { createBrowserRouter } from "react-router-dom"; import { ROUTE_NAMES } from "./routeNames"; import { Home } from "./components/Home"; import { About } from "./components/About"; import { Result } from "antd"; import {TourProvider} from "./TourContext"; const GetItem = (label, key, icon, to, children = [], type) => { return !to ? { key, icon, children, label, type, } : { key, icon, to, label, }; }; const GetRoute = (path, element, params = null) => { return { path, element, }; }; const WithAppLayout = (Component) => <TourProvider><AppLayout>{Component}</AppLayout></TourProvider>; export const routeItems = [ GetItem("Home", "home", null, ROUTE_NAMES.HOME), GetItem("About", "about", null, ROUTE_NAMES.ABOUT), ]; const AppRouter = createBrowserRouter([ GetRoute(ROUTE_NAMES.HOME, WithAppLayout(<Home />)), GetRoute(ROUTE_NAMES.ABOUT, WithAppLayout(<About />)), GetRoute( "*", <Result status="404" title="404" subTitle="Sorry, the page you visited does not exist." /> ), ]); export default AppRouter;
Étape 1 : Configurer un contexte de tournée mondiale
Nous utilisons React Context pour gérer l'état global de la visite, y compris les étapes actives de la visite.
import React, { createContext, useState, useEffect } from "react"; import { useNavigate } from "react-router-dom"; import { APP_TOURS } from "./steps"; const TourContext = createContext(); export const TourProvider = ({ children }) => { const [isTourActive, setTourActive] = useState(false); const navigate = useNavigate(); useEffect(() => { if (isTourActive) { navigate("/home"); // Redirect to the starting point of the tour } }, [isTourActive, navigate]); return ( <TourContext.Provider value={{ isTourActive, setTourActive, steps: APP_TOURS }}> {children} </TourContext.Provider> ); }; export default TourContext;
Étape 2 : Définir les étapes de la tournée mondiale
Au lieu des références React, nous utilisons querySelector pour récupérer dynamiquement des éléments à l'aide d'un attribut data-tour-id personnalisé.
const getTourStepElement = (id) => document.querySelector(`[data-tour-id="${id}"]`); export const APP_TOURS = { "/home": [ { title: "Upload File", description: "Put your files here.", target: () => getTourStepElement("upload") }, { title: "Save", description: "Save your changes.", target: () => getTourStepElement("save") }, { type: "navigate", to: "/about", title: "About Us", description: "Learn more about us." }, ], "/about": [ { title: "About Us", description: "Here's what we are all about.", target: () => getTourStepElement("about") }, ], };
Étape 3 : Créer un composant de visite mondiale
Ce composant gère dynamiquement la navigation et les étapes à travers les pages.
import React, { useContext } from "react"; import { Tour } from "antd"; import { useNavigate } from "react-router-dom"; import TourContext from "./TourContext"; export const GlobalTour = () => { const { isTourActive, steps, setTourActive } = useContext(TourContext); const navigate = useNavigate(); return ( <Tour open={isTourActive} onClose={() => setTourActive(false)} steps={steps} onChange={(current) => { const step = steps[current]; if (step.type === "navigate") { navigate(step.to); } }} /> ); };
Étape 4 : Intégrer dans la mise en page de l'application
La visite est parfaitement intégrée à la mise en page, accessible depuis n'importe quelle page.
import React, { useContext } from "react"; import { Layout, Button } from "antd"; import { Link } from "react-router-dom"; import TourContext from "./TourContext"; import { GlobalTour } from "./GlobalTour"; const { Header, Content, Footer } = Layout; const AppLayout = ({ children }) => { const { setTourActive } = useContext(TourContext); return ( <Layout> <Header> <Link to="/home">Home</Link> <Link to="/about">About</Link> <Button onClick={() => setTourActive(true)}>Start Tour</Button> </Header> <Content>{children}</Content> <Footer>© {new Date().getFullYear()} My App</Footer> <GlobalTour /> </Layout> ); }; export default AppLayout;
Étape 5 : Ajouter des identifiants de visite d'étapes
Étant donné que notre visite s'étend sur plusieurs pages, nous attribuerons un data-tour-id à chaque composant que nous souhaitons mettre en évidence dans nos étapes
import { Button, Space } from "antd"; import { EllipsisOutlined } from "@ant-design/icons"; export const Home = () => { return ( <> <Button data-tour-id="upload" >Upload</Button> <Button data-tour-id="save" type="primary"> Save </Button> <Button data-tour-id="actions" icon={<EllipsisOutlined />} /> </> ); };
export const About = () => { return <div data-tour-id="about">About</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

Des questions et des solutions fréquemment posées pour l'impression de billets thermiques frontaux pour le développement frontal, l'impression de billets est une exigence commune. Cependant, de nombreux développeurs mettent en œuvre ...

JavaScript est la pierre angulaire du développement Web moderne, et ses principales fonctions incluent la programmation axée sur les événements, la génération de contenu dynamique et la programmation asynchrone. 1) La programmation axée sur les événements permet aux pages Web de changer dynamiquement en fonction des opérations utilisateur. 2) La génération de contenu dynamique permet d'ajuster le contenu de la page en fonction des conditions. 3) La programmation asynchrone garantit que l'interface utilisateur n'est pas bloquée. JavaScript est largement utilisé dans l'interaction Web, les applications à une page et le développement côté serveur, améliorant considérablement la flexibilité de l'expérience utilisateur et du développement multiplateforme.

Il n'y a pas de salaire absolu pour les développeurs Python et JavaScript, selon les compétences et les besoins de l'industrie. 1. Python peut être davantage payé en science des données et en apprentissage automatique. 2. JavaScript a une grande demande dans le développement frontal et complet, et son salaire est également considérable. 3. Les facteurs d'influence comprennent l'expérience, la localisation géographique, la taille de l'entreprise et les compétences spécifiques.

La discussion sur la réalisation des effets de défilement de parallaxe et d'animation des éléments dans cet article explorera comment réaliser le site officiel de Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ...

Apprendre JavaScript n'est pas difficile, mais c'est difficile. 1) Comprendre les concepts de base tels que les variables, les types de données, les fonctions, etc. 2) Master la programmation asynchrone et les implémenter via des boucles d'événements. 3) Utilisez les opérations DOM et promettez de gérer les demandes asynchrones. 4) Évitez les erreurs courantes et utilisez des techniques de débogage. 5) Optimiser les performances et suivre les meilleures pratiques.

Les dernières tendances de JavaScript incluent la montée en puissance de TypeScript, la popularité des frameworks et bibliothèques modernes et l'application de WebAssembly. Les prospects futurs couvrent des systèmes de type plus puissants, le développement du JavaScript côté serveur, l'expansion de l'intelligence artificielle et de l'apprentissage automatique, et le potentiel de l'informatique IoT et Edge.

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en JavaScript? Lors du traitement des données, nous rencontrons souvent la nécessité d'avoir le même ID ...

Explorez la mise en œuvre de la fonction de glisser et de réglage du panneau de type VScode dans le frontal. Dans le développement frontal, comment implémenter un VScode comme ...
