Le principe et l'utilisation de la fonction de rappel Node.js

Les fonctions de rappel sont un modèle de programmation asynchrone courant dans Node.js. Il vous permet d'exécuter un code spécifique après la fin d'une opération. Les fonctions de rappel sont très courantes lorsqu'il s'agit d'opérations d'E/S, de gestion d'événements et de tâches asynchrones. Cet article présentera en détail le principe, l'utilisation et certains problèmes courants de la fonction de rappel Node.js.

Qu'est-ce qu'une fonction de rappel ?

Une fonction de rappel est une fonction d'ordre supérieur, c'est-à-dire une fonction passée en paramètre à d'autres fonctions et appelée ultérieurement. Dans la programmation asynchrone, les fonctions de rappel sont souvent utilisées pour gérer des opérations différées, telles que la lecture de fichiers, l'envoi de requêtes réseau ou la gestion d'événements.

Les caractéristiques communes des fonctions de rappel incluent :

  • Passer des fonctions comme arguments à d'autres fonctions.
  • Exécutez la fonction une fois l'opération terminée.
  • Habituellement, la convention erreur en premier est utilisée, c'est-à-dire que le premier argument de la fonction de rappel est l'objet d'erreur (s'il y a une erreur) et les arguments suivants sont les données renvoyées.

Node.js utilise des fonctions de rappel pour éviter le blocage des E/S et améliorer la simultanéité et les performances.

Comment utiliser la fonction de rappel

Dans Node.js, le flux général d'utilisation d'une fonction de rappel est le suivant :

  1. Définit une opération qui doit être exécutée paresseusement, comme la lecture d'un fichier ou l'envoi d'une requête réseau.
  2. Définissez une fonction de rappel dans la liste des paramètres de la fonction.
  3. La fonction de rappel est invoquée une fois l'opération terminée, en lui transmettant le résultat ou une erreur en tant qu'argument.

Voici un exemple simple qui montre comment lire un fichier à l'aide d'une fonction de rappel :

const fs = require('fs');

function readFile(filename, callback) {
    
    
  fs.readFile(filename, 'utf8', (err, data) => {
    
    
    if (err) {
    
    
      callback(err); // 处理错误
    } else {
    
    
      callback(null, data); // 处理数据
    }
  });
}

readFile('example.txt', (err, data) => {
    
    
  if (err) {
    
    
    console.error('Error:', err);
  } else {
    
    
    console.log('Data:', data);
  }
});

Dans le code ci-dessus, readFilela fonction accepte deux paramètres : le nom du fichier et la fonction de rappel. Il utilise fs.readFilela méthode de Node.js pour lire le contenu du fichier et appelle la fonction de rappel en fonction du résultat de la lecture. Si une erreur se produit, l'objet d'erreur est transmis à la fonction de rappel en tant que premier paramètre ; si le fichier a été lu avec succès, les données sont transmises à la fonction de rappel en tant que deuxième paramètre.

la gestion des erreurs

Il est très important de gérer les erreurs dans la fonction de rappel. Généralement, le premier argument de la fonction de rappel de convention est un objet d'erreur indiquant si l'opération a réussi. Si l'opération réussit, l'objet d'erreur est nullou undefined; si l'opération échoue, les informations d'erreur sont transmises via l'objet d'erreur.

Voici un exemple qui montre comment gérer les erreurs dans la fonction de rappel :

function doSomething(callback) {
    
    
  // 模拟一个异步操作
  setTimeout(() => {
    
    
    const success = Math.random() < 0.5;
    if (success) {
    
    
      callback(null, 'Success');
    } else {
    
    
      callback(new Error('An error occurred'));
    }
  }, 1000);
}

doSomething((err, result) => {
    
    
  if (err) {
    
    
    console.error('Error:', err);
  } else {
    
    
    console.log('Result:', result);
  }
});

Dans le code ci-dessus, doSomethingla fonction simule une opération asynchrone. En cas de réussite, la fonction de rappel sera appelée et transmettra les données ; si une erreur se produit, la fonction de rappel sera appelée et transmettra l'objet d'erreur.

L'enfer du rappel et la solution

Dans les opérations asynchrones complexes, l'utilisation de plusieurs fonctions de rappel peut conduire à un code confus et impossible à maintenir, appelé "Callback Hell". Afin de résoudre ce problème, les méthodes suivantes peuvent être adoptées :

  1. Utilisation de fonctions nommées : Définissez chaque fonction de rappel comme une fonction nommée distincte, qui est ensuite transmise en tant qu'argument à l'opération asynchrone.
  2. Utiliser des promesses : les promesses sont un nouveau paradigme pour la programmation asynchrone qui fournit des structures de code plus propres et plus lisibles.

Voici un exemple utilisant Promises :

const fs = require('fs').promises;

function readFile(filename) {
    
    
  return fs.readFile(filename, 'utf8');
}

readFile('example.txt')
  .then(data => {
    
    
    console.log('Data:', data);
  })
  .catch(err => {
    
    
    console.error('Error:', err);
  });

Dans le code ci-dessus, fs.readFilela méthode renvoie une promesse, qui peut .then()gérer le succès de l'opération via et .catch()l'échec de l'opération via .

en conclusion

Les fonctions de rappel sont un concept important dans la programmation asynchrone Node.js, qui vous permettent d'exécuter un code spécifique après la fin d'une opération. Cet article présente en détail le principe, l'utilisation et la gestion des erreurs de la fonction de rappel, et comment éviter le problème de l'enfer du rappel. En outre, une alternative à l'utilisation de Promises est présentée.

Je suppose que tu aimes

Origine blog.csdn.net/weixin_43025343/article/details/131894905
conseillé
Classement