Programmation asynchrone Javascript

Mobile Features AB

La programmation asynchrone JavaScript permet un développement web efficace en permettant aux tâches de fonctionner indépendamment du fil d'exécution principal, évitant ainsi que les applications web ne deviennent insensibles. Cette technique s'appuie sur les promesses, async/await et les callbacks pour gérer les opérations qui prennent du temps, comme la récupération de données sur un serveur. Comprendre la programmation asynchrone est fondamental pour que les développeurs puissent créer des expériences utilisateur transparentes et interactives dans les applications web modernes.

C'est parti

Des millions de fiches spécialement conçues pour étudier facilement

Inscris-toi gratuitement

Achieve better grades quicker with Premium

PREMIUM
Karteikarten Spaced Repetition Lernsets AI-Tools Probeklausuren Lernplan Erklärungen Karteikarten Spaced Repetition Lernsets AI-Tools Probeklausuren Lernplan Erklärungen
Kostenlos testen

Geld-zurück-Garantie, wenn du durch die Prüfung fällst

Review generated flashcards

Inscris-toi gratuitement
Tu as atteint la limite quotidienne de l'IA

Commence à apprendre ou crée tes propres flashcards d'IA

Équipe éditoriale StudySmarter

Équipe enseignants Programmation asynchrone Javascript

  • Temps de lecture: 19 minutes
  • Vérifié par l'équipe éditoriale StudySmarter
Sauvegarder l'explication Sauvegarder l'explication
Sign up for free to save, edit & create flashcards.
Sauvegarder l'explication Sauvegarder l'explication
  • Fact Checked Content
  • reading time:19 min
Tables des matières
Tables des matières
  • Fact Checked Content
  • Last Updated: 01.01.1970
  • reading time:19 min
  • Content creation process designed by
    Lily Hulatt Avatar
  • Content cross-checked by
    Gabriel Freitas Avatar
  • Content quality checked by
    Gabriel Freitas Avatar
Sign up for free to save, edit & create flashcards.
Sauvegarder l'explication Sauvegarder l'explication

Sauter à un chapitre clé

    Qu'est-ce que la programmation asynchrone en Javascript ?

    Laprogrammation asynchrone en Javascript est un concept fondamental qui permet à ton code d'exécuter des tâches en arrière-plan sans bloquer l'exécution des opérations suivantes. Cela est particulièrement utile pour effectuer des tâches qui prennent un temps imprévisible, comme la récupération de données sur un serveur, la lecture de fichiers ou d'autres opérations d'entrée/sortie. En utilisant la programmation asynchrone, tu peux améliorer les performances et la réactivité de tes applications.

    Comprendre les bases des opérations asynchrones

    La base des opérations asynchrones en Javascript repose sur la boucle d'événements, les promesses et la syntaxe async/await. Contrairement à l'exécution synchrone traditionnelle, où les tâches sont accomplies l'une après l'autre, les opérations asynchrones permettent à Javascript d'initier une tâche et de passer à la suivante sans attendre la fin de la tâche précédente. Pour ce faire, on utilise des fonctions de rappel, des promesses et la syntaxe moderne async/await, qui simplifient le travail avec les opérations asynchrones.

    Fonctions de rappel : Fonctions qui sont passées en tant qu'arguments à d'autres fonctions et qui sont invoquées lorsqu'une opération asynchrone se termine. Elles permettent d'effectuer des actions après la fin de l'opération.

    Promesses : Objets qui représentent l'achèvement éventuel (ou l'échec) d'une opération asynchrone, et sa valeur résultante. Les promesses peuvent être enchaînées et sont utilisées pour gérer un contrôle de flux asynchrone complexe.

    Async/Await : Une syntaxe qui rend le travail avec les promesses plus simple. Le mot-clé async est ajouté aux fonctions pour renvoyer une promesse, et le mot-clé await est utilisé avant une fonction qui renvoie une promesse, mettant en pause l'exécution jusqu'à ce que la promesse soit résolue ou rejetée.

    function fetchData() { return new Promise((resolve, reject) => { setTimeout(() => resolve('Data fetched'), 2000) ; }) ; } async function showData() { const data = await fetchData() ; console.log(data) ; } showData() ;

    Cet exemple montre comment récupérer des données de manière asynchrone en utilisant la syntaxe async/await. La fonction fetchData simule la récupération de données avec un délai, en renvoyant une promesse. La fonction showData attend ensuite la résolution de cette promesse avant d'enregistrer les données.

    En quoi la programmation asynchrone diffère-t-elle de la programmation synchrone en Javascript ?

    En Javascript, la programmation synchrone suit un chemin d'exécution linéaire, où chaque instruction doit se terminer avant que la suivante ne commence. Cette approche directe garantit la prévisibilité mais peut conduire à des inefficacités, en particulier lorsqu'il s'agit de tâches qui prennent du temps. En revanche, la programmation asynchrone s'écarte de ce modèle linéaire et permet de traiter plusieurs tâches simultanément. Cette différence n'est pas seulement conceptuelle ; elle change fondamentalement la façon dont les applications sont construites, les rendant plus efficaces et plus réactives.

    Imagine le chargement d'une page Web contenant plusieurs images. Dans un environnement synchrone, chaque image se chargerait l'une après l'autre, ce qui pourrait nuire à l'expérience de l'utilisateur si l'une d'entre elles mettait beaucoup de temps à être récupérée. En revanche, avec des opérations asynchrones, toutes les images pourraient commencer à se charger en même temps, ce qui améliorerait considérablement le temps de chargement de la page et l'expérience de l'utilisateur. Cette analogie illustre la puissance de la programmation asynchrone dans la création d'applications Web fluides et conviviales.

    Pourquoi la programmation asynchrone est-elle importante en Javascript ?

    Laprogrammation asynchrone en Javascript joue un rôle central dans la création d'applications web réactives et performantes. En permettant à certaines parties du code de s'exécuter simultanément sans en bloquer d'autres, elle améliore considérablement l'expérience d'interaction avec l'utilisateur. En particulier lorsqu'il s'agit de tâches telles que la récupération de données, le traitement de fichiers volumineux ou toute opération qui bloquerait traditionnellement le fil d'exécution, la programmation asynchrone garantit que ton application reste réactive et efficace.

    Améliorer l'expérience de l'utilisateur grâce à la programmation asynchrone

    Du point de vue de l'utilisateur, la réactivité et la vitesse sont des aspects non négociables d'une bonne application web. La programmation asynchrone permet aux développeurs de répondre à ces attentes en éliminant les frustrations liées aux temps d'attente inutiles. Les opérations qui pourraient prendre beaucoup de temps sont traitées en arrière-plan, ce qui permet aux utilisateurs de continuer à interagir avec l'application. Cela améliore considérablement la performance perçue et la satisfaction générale, en évitant les pièges courants des interfaces qui ne répondent pas ou qui sont lentes.

    Exemple : Imagine un utilisateur qui soumet un formulaire et reçoit un retour d'information immédiat, comme un message de confirmation, alors que les données sont traitées et enregistrées en arrière-plan. Cette boucle de rétroaction immédiate, rendue possible par les opérations asynchrones, améliore considérablement l'expérience de l'utilisateur.

    function saveFormData(data) { return new Promise((resolve, reject) => { setTimeout(() => { // simuler l'enregistrement des données puis résoudre la promesse console.log('Data saved') ; resolve('Success') ; }, 1000) ; }) ; } async function submitForm() { console.log('Form submitted') ; const result = await saveFormData({name : 'John Doe'}) ; console.log(result) ; // Enregistre 'Success' après une seconde } submitForm() ;

    Cet exemple démontre la soumission asynchrone d'un formulaire, où le processus d'enregistrement des données est simulé par une promesse différée. L'enregistrement immédiat de "Formulaire soumis", suivi du message de traitement, illustre les opérations non bloquantes.

    Le rôle de la programmation asynchrone dans le développement Web

    La programmation asynchrone ne sert pas seulement à améliorer l'expérience de l'utilisateur ; elle fait partie intégrante du développement Web moderne. En tirant parti des techniques asynchrones, les développeurs peuvent exploiter tout le potentiel de la nature monotâche de Javascript pour effectuer plusieurs opérations simultanément. Ceci est particulièrement vital dans les scénarios impliquant des appels d'API, le traitement de données en temps réel, et lors de la gestion d'états dans des applications complexes. La capacité à effectuer ces tâches sans interrompre le fil d'exécution principal ou provoquer le gel de l'interface utilisateur est ce qui distingue les applications Web performantes.

    De plus, la programmation asynchrone permet d'obtenir des structures de code plus propres et plus faciles à gérer grâce à l'utilisation de promesses et de modèles asynchrones/attendus. Ces constructions fournissent un cadre robuste pour gérer les opérations asynchrones, ce qui simplifie grandement le contrôle du flux et améliore la lisibilité et la maintenance du code.

    • Améliore l'évolutivité des applications Web en gérant efficacement plusieurs opérations simultanées.
    • Permet de récupérer et de traiter des données en temps réel sans recharger les pages, ce qui est crucial pour les applications Web dynamiques.
    • Facilite la gestion des erreurs dans les processus asynchrones par rapport aux modèles de rappel traditionnels.

    La syntaxe async/await en Javascript, introduite dans ES2017, est un sucre syntaxique construit au-dessus des promesses. Elle permet d'écrire du code asynchrone qui ressemble et se comporte comme du code synchrone.

    Alors que l'Internet des objets (IoT) et les applications web en temps réel continuent de se développer, la demande de modèles de programmation efficaces et asynchrones en Javascript augmente également. Cette demande met en évidence la nature évolutive du développement web, s'orientant vers des applications qui non seulement fonctionnent de manière transparente à travers les appareils, mais qui traitent également les données en temps réel, améliorant à la fois l'évolutivité et la fiabilité des services web. La programmation asynchrone est au cœur de cette évolution, permettant aux développeurs de créer des applications sophistiquées et performantes qui répondent aux attentes de l'utilisateur moderne.

    Exemple de programmation asynchrone en Javascript

    La programmation asynchrone Javascript est une compétence essentielle pour développer des applications web performantes et réactives. Dans cette section, des exemples sont fournis pour montrer comment la programmation asynchrone est mise en œuvre et appliquée dans des scénarios réels. En commençant par une simple fonction asynchrone et en passant à des applications réelles plus complexes, ces exemples servent de guides pratiques pour maîtriser les opérations asynchrones en Javascript.

    Mise en œuvre d'une fonction asynchrone simple

    La création d'une fonction asynchrone simple en Javascript peut être réalisée à l'aide de promesses, l'un des concepts fondamentaux de la programmation asynchrone. Une promesse représente une opération qui n'est pas encore terminée mais qui est attendue dans le futur. En mettant en œuvre des fonctions asynchrones, le code qui effectue des tâches potentiellement longues peut s'exécuter sans bloquer d'autres opérations.

    Un exemple de fonction asynchrone simple pourrait consister à récupérer des données sur un serveur distant. L'opération peut prendre un certain temps en raison de la latence du réseau. Pour éviter que cette opération ne bloque le thread principal, l'API fetch, qui renvoie une promesse, peut être utilisée.

    function getData(url) { return fetch(url) .then(response => response.json()) .then(data => console.log(data)) .catch(error => console.error('Error fetching data:', error)) ; } getData('https://api.example.com/data') ;

    Dans cet exemple, getData est une fonction qui récupère les données d'une URL donnée. Elle utilise fetch, une API native du navigateur qui prend en charge les promesses. Cet exemple montre comment la programmation asynchrone permet au reste de l'application de continuer à fonctionner pendant que les données sont récupérées, ce qui améliore la réactivité des applications Web.

    Application réelle de la programmation asynchrone en Javascript

    Dans le développement Web réel, la programmation asynchrone est fréquemment utilisée pour améliorer l'expérience de l'utilisateur en permettant aux applications Web d'effectuer des tâches en arrière-plan, telles que la récupération de données, sans geler l'interface utilisateur. Ceci est particulièrement bénéfique dans les scénarios où l'application doit afficher un contenu frais et mis à jour sans nécessiter un rechargement de la page.

    Une application courante de la programmation asynchrone dans la vie réelle est le développement d'applications à page unique (SPA). Les SPA s'appuient fortement sur le JavaScript et le XML asynchrones (AJAX) pour récupérer des données de manière asynchrone depuis le backend sans recharger la page Web, ce qui permet d'offrir à l'utilisateur une expérience fluide et homogène.

    function updateContent() { fetch('https://api.example.com/content') .then(response => response.json()) .then(data => { document.getElementById('main-content').innerHTML = data.newContent ; }) .catch(error => console.error('Error updating content:', error)) ; } setInterval(updateContent, 60000) ;

    Cet exemple montre comment une fonction, updateContent, met périodiquement à jour le contenu d'une page Web sans recharger la page entière. Elle récupère le nouveau contenu d'une URL donnée toutes les 60 secondes à l'aide de setInterval, puis met à jour la page Web si de nouvelles données sont récupérées. Ce modèle est couramment utilisé dans les sites Web d'actualités, les flux de médias sociaux et d'autres applications où de nouveaux contenus sont fréquemment ajoutés.

    Dans les applications réelles, la gestion des erreurs est un aspect essentiel de la programmation asynchrone. Assure-toi que les promesses incluent un bloc .catch() ou des instructions try-catch lorsque tu utilises async/await, afin de gérer de manière élégante les erreurs potentielles ou les opérations qui échouent.

    Différences entre la programmation synchrone et asynchrone en Javascript

    Comprendre les distinctions entre la programmation synchrone et asynchrone en Javascript est crucial pour développer des applications web efficaces. Alors que le code synchrone s'exécute de manière séquentielle, bloquant les opérations suivantes jusqu'à ce que l'opération en cours soit terminée, la programmation asynchrone permet à certaines opérations de s'exécuter en arrière-plan, améliorant ainsi les performances de l'application et l'expérience de l'utilisateur.

    Les principales différences expliquées à l'aide d'exemples

    Les différences fondamentales entre la programmation synchrone et asynchrone peuvent être dépeintes à travers leur modèle d'exécution, leur impact sur les performances de l'application et leur facilité de compréhension et de débogage.

    • La programmation synchrone exécute les tâches l'une après l'autre, ce qui conduit souvent à des interfaces potentiellement insensibles lors d'opérations longues ou complexes.
    • La programmation asynchrone permet aux opérations de s'exécuter indépendamment du flux d'exécution principal, ce qui permet à l'application de rester interactive.
    console.log('Start') ; // Opération synchrone for(let i = 0 ; i < 3 ; i++) { console.log(i) ; } console.log('End') ; // Sortie : // Start // 0 // 1 // 2 // End

    Ceci démontre une opération synchrone où les journaux sont exécutés dans l'ordre exact.

    console.log('Start') ; // Opération asynchrone utilisant setTimeout setTimeout(() => { console.log('Inside setTimeout') ; }, 1000) ; console.log('End') ; // Sortie : // Début // Fin // (après 1 seconde) Inside setTimeout

    Cet exemple illustre une opération asynchrone, où setTimeout permet à la dernière instruction de journal de s'exécuter avant la fin du délai d'attente.

    Choisir entre la programmation synchrone et asynchrone : Quand et pourquoi

    La décision d'utiliser la programmation synchrone ou asynchrone en Javascript dépend de plusieurs facteurs, notamment la tâche spécifique à accomplir, les considérations relatives à l'expérience de l'utilisateur et l'architecture globale de l'application.

    • Pour les opérations rapides à effectuer et où l'ordre est primordial, la programmation synchrone est préférable.
    • La programmation asynchrone est idéale pour les tâches qui peuvent prendre un temps indéterminé, comme la récupération de données sur un serveur, sans geler l'interface utilisateur.

    Cas d'utilisation de la programmation synchrone : Itération sur un tableau pour effectuer des calculs où le résultat de l'opération en cours ne dépend pas de l'achèvement d'une opération précédente.

    Cas d'utilisation pour la programmation asynchrone : Interactions avec l'utilisateur, opérations d'entrée/sortie, recherche de données dans une base de données ou une API, où la réponse immédiate à l'utilisateur est une priorité, et où les opérations peuvent être traitées en arrière-plan.

    Javascript utilise une "boucle d'événements" pour gérer les opérations asynchrones, ce qui permet des fonctionnalités non bloquantes malgré sa nature monotâche.

    Lorsque tu intègres des services tiers ou des API dans ton application, la programmation asynchrone devient indispensable. Elle permet à l'application de faire des demandes de données ou de traitement au serveur et de continuer à exécuter d'autres scripts en attendant la réponse. Ce comportement asynchrone est vital pour créer une expérience utilisateur transparente, en particulier dans les applications complexes qui impliquent un traitement lourd des données ou de multiples interactions de va-et-vient avec le serveur.

    Utilisations de la programmation asynchrone en Javascript

    Laprogrammation as ynchrone en Javascript n'est pas qu'une simple fonctionnalité ; c'est une stratégie cruciale pour améliorer les performances des applications web et l'expérience des utilisateurs. En comprenant et en mettant en œuvre des modèles asynchrones, les développeurs peuvent s'attaquer à une variété de tâches courantes dans le développement Web, allant des appels API à la manipulation de données complexes, sans compromettre la réactivité de l'interface.

    Cas d'utilisation courants dans les applications Web

    La programmation asynchrone en Javascript trouve son application dans divers aspects du développement Web. Elle simplifie la gestion d'opérations telles que les demandes d'API, les téléchargements de fichiers et même les minuteries, ce qui permet d'intégrer ces processus de manière transparente dans l'expérience de l'utilisateur sans provoquer de retards ou de blocages.

    • Faire des demandes d'API pour récupérer ou envoyer des données sans recharger la page.
    • Télécharger des fichiers et traiter des données en arrière-plan.
    • Définir des minuteries ou des délais dans les interactions avec l'utilisateur.
    • Effectuer de longs calculs sans bloquer l'interface utilisateur.
    async function getUserData(userId) { let response = await fetch(`https://api.example.com/users/${userId}`) ; let data = await response.json() ; console.log(data) ; } getUserData('123') ;

    Cet exemple illustre la récupération asynchrone des données de l'utilisateur à partir d'une API, ce qui empêche l'interface utilisateur de se figer pendant l'attente de la réponse.

    Comment la programmation asynchrone améliore les performances et la réactivité

    Au cœur de l'amélioration des performances et de la réactivité des applications Web grâce à la programmation asynchrone se trouve sa nature non bloquante. En permettant l'exécution de certaines opérations en arrière-plan, elle permet à l'application de rester totalement interactive. Cela est particulièrement bénéfique dans le web d'aujourd'hui, où les attentes des utilisateurs en matière d'expériences web rapides et réactives sont plus élevées que jamais.

    Non-blocage : Une caractéristique essentielle de la programmation asynchrone où les opérations peuvent s'exécuter en parallèle à l'exécution du code principal, ce qui permet d'éviter les retards dans l'interface utilisateur.

    • Améliore les temps de chargement en allant chercher les ressources en parallèle.
    • Améliore l'expérience de l'utilisateur en maintenant une interface réactive.
    • Permet un traitement efficace des grands ensembles de données sans perturber l'expérience de l'utilisateur.

    Prends l'exemple d'une application Web qui nécessite des données en direct provenant de plusieurs sources, telles que les cours de la bourse, les mises à jour météorologiques et les fils d'actualité. En utilisant la programmation asynchrone, l'application peut faire des demandes simultanées pour ces données, en mettant à jour l'interface utilisateur en temps réel au fur et à mesure que chaque demande se termine. Cette approche permet non seulement de s'assurer que l'application fournit les informations les plus récentes sans délai, mais aussi de maintenir des performances optimales, ce qui démontre la puissance de la programmation asynchrone dans la création d'expériences web dynamiques et axées sur les données.

    La nature monotâche de Javascript fait du modèle asynchrone non seulement une option mais une nécessité pour traiter plusieurs opérations simultanément sans geler l'interface utilisateur.

    Programmation asynchrone en Javascript - Principaux enseignements

    • Programmation asynchrone en Javascript : Permet d'exécuter des tâches en arrière-plan sans bloquer les opérations suivantes, ce qui améliore les performances et la réactivité de l'application.
    • Opérations asynchrones : Initiées par Javascript et se poursuivent sans interrompre le flux d'exécution principal à l'aide de fonctions de rappel, de promesses et d'async/await.
    • Différence entre la programmation synchrone et asynchrone : Le code synchrone s'exécute de manière séquentielle, tandis que la programmation asynchrone traite les tâches de manière concurrente, ce qui améliore l'efficacité et l'expérience de l'utilisateur.
    • Utilisations de la programmation asynchrone en Javascript : Améliore les applications web en permettant aux requêtes API, au traitement des données et aux interactions des utilisateurs de se produire sans recharger les pages ou geler l'interface utilisateur.
    • Syntaxe Async/Await : Simplifie l'écriture de code asynchrone en Javascript en lui donnant l'apparence d'un code synchrone, ce qui améliore la lisibilité et le contrôle du flux.
    Apprends plus vite avec les 27 fiches sur Programmation asynchrone Javascript

    Inscris-toi gratuitement pour accéder à toutes nos fiches.

    Programmation asynchrone Javascript
    Questions fréquemment posées en Programmation asynchrone Javascript
    Qu'est-ce que la programmation asynchrone en JavaScript ?
    La programmation asynchrone en JavaScript permet d'exécuter des tâches sans bloquer le fil principal, grâce à des opérations non bloquantes comme les promesses et async/await.
    Comment fonctionnent les promesses en JavaScript ?
    Les promesses en JavaScript représentent des opérations asynchrones, permettant de gérer des résultats futurs avec les méthodes then et catch.
    Qu'est-ce que async/await en JavaScript ?
    Async/await est une syntaxe qui simplifie l'écriture de code asynchrone, permettant d'utiliser les promesses de manière plus lisible.
    Pourquoi utiliser la programmation asynchrone ?
    La programmation asynchrone améliore la performance des applications en évitant des blocages, ce qui est crucial pour les applications web modernes.
    Sauvegarder l'explication

    Teste tes connaissances avec des questions à choix multiples

    Qu'est-ce que la programmation asynchrone en Javascript ?

    Quels sont les principes de base de la programmation asynchrone en Javascript ?

    Quel rôle joue la programmation asynchrone en Javascript ?

    Suivant
    How we ensure our content is accurate and trustworthy?

    At StudySmarter, we have created a learning platform that serves millions of students. Meet the people who work hard to deliver fact based content as well as making sure it is verified.

    Content Creation Process:
    Lily Hulatt Avatar

    Lily Hulatt

    Digital Content Specialist

    Lily Hulatt is a Digital Content Specialist with over three years of experience in content strategy and curriculum design. She gained her PhD in English Literature from Durham University in 2022, taught in Durham University’s English Studies Department, and has contributed to a number of publications. Lily specialises in English Literature, English Language, History, and Philosophy.

    Get to know Lily
    Content Quality Monitored by:
    Gabriel Freitas Avatar

    Gabriel Freitas

    AI Engineer

    Gabriel Freitas is an AI Engineer with a solid experience in software development, machine learning algorithms, and generative AI, including large language models’ (LLMs) applications. Graduated in Electrical Engineering at the University of São Paulo, he is currently pursuing an MSc in Computer Engineering at the University of Campinas, specializing in machine learning topics. Gabriel has a strong background in software engineering and has worked on projects involving computer vision, embedded AI, and LLM applications.

    Get to know Gabriel

    Découvre des matériels d'apprentissage avec l'application gratuite StudySmarter

    Lance-toi dans tes études
    1
    À propos de StudySmarter

    StudySmarter est une entreprise de technologie éducative mondialement reconnue, offrant une plateforme d'apprentissage holistique conçue pour les étudiants de tous âges et de tous niveaux éducatifs. Notre plateforme fournit un soutien à l'apprentissage pour une large gamme de sujets, y compris les STEM, les sciences sociales et les langues, et aide également les étudiants à réussir divers tests et examens dans le monde entier, tels que le GCSE, le A Level, le SAT, l'ACT, l'Abitur, et plus encore. Nous proposons une bibliothèque étendue de matériels d'apprentissage, y compris des flashcards interactives, des solutions de manuels scolaires complètes et des explications détaillées. La technologie de pointe et les outils que nous fournissons aident les étudiants à créer leurs propres matériels d'apprentissage. Le contenu de StudySmarter est non seulement vérifié par des experts, mais également régulièrement mis à jour pour garantir l'exactitude et la pertinence.

    En savoir plus
    Équipe éditoriale StudySmarter

    Équipe enseignants Informatique

    • Temps de lecture: 19 minutes
    • Vérifié par l'équipe éditoriale StudySmarter
    Sauvegarder l'explication Sauvegarder l'explication

    Sauvegarder l'explication

    Inscris-toi gratuitement

    Inscris-toi gratuitement et commence à réviser !

    Rejoins plus de 22 millions d'étudiants qui apprennent avec notre appli StudySmarter !

    La première appli d'apprentissage qui a réunit vraiment tout ce dont tu as besoin pour réussir tes examens.

    • Fiches & Quiz
    • Assistant virtuel basé sur l’IA
    • Planificateur d'étude
    • Examens blancs
    • Prise de notes intelligente
    Rejoins plus de 22 millions d'étudiants qui apprennent avec notre appli StudySmarter !