Titre réécrit comme : La fonction asynchrone récursive ne peut pas renvoyer de valeur
P粉729518806
2023-08-29 21:11:13
<p>Je crée une fonction asynchrone récursive qui exécute une requête MySQL. Voici la base de données que j'utilise : </p>
<pre class="brush:php;toolbar:false;">+----+-------------------+------- ----+----------+-----------+-------------------------+
| ID tâche | terminé | ID parent | créé par |
+----+-----------+-----------+--------------+- -------- ---+---------------------+
| 1 | Appartement propre | 0 | NULL 1 |
| 2 | Nettoyer la salle de bain | 0 | 1 | 2022-03-24 00:47:33 |
| 3 | Nettoyer la cuisine | 0 | 1 | 2022-03-24 00:47:33 |
| 4 | Prendre une douche | 0 | 2 | 2022-03-24 00:47:33 |
| 5 | Laver les toilettes | 0 | 2 | 2022-03-24 00:47:33 |
| 6 | Nettoyage des vitres | 1 | 4 | 2022-03-24 00:47:33 |
| 7 | Nettoyer les robinets | 0 | 4 | 2022-03-24 00:47:33 |
| 8 | Nettoyer l'évier | 0 | 3 | 2022-03-24 00:47:33 |
| 9 | Sortir la poubelle | 1 | 3 | 2022-03-24 00:47:33 |
+----+-----------+-----------+--------------+- -------- ---+-----------+</pré>
<p>Si je stocke cette base de données dans un tableau, je peux exécuter cette fonction : </p>
<pre class="brush:php;toolbar:false;">function comp(tasks, taskId) {
var task = tâches.find(task => task.id === taskId)
var enfants = tâches.filter(t => t.parentId === taskId)
task.children = children.map(child => comp(tasks, child.id));
tâche de retour
}</pré>
<p> pour imbriquer récursivement des sous-tâches dans la tâche principale. </p>
<p>Le problème est que je ne comprends pas assez bien les fonctions asynchrones.</p>
<p>Voici mes progrès jusqu'à présent : </p>
<pre class="brush:php;toolbar:false;">async function comp(taskId) {
// SELECT * FROM tâches OÙ id = taskId
var task = wait con.promise().query('select * from tâches où id = ' + taskId)
// SELECT * FROM tâches OÙ parentId = taskId
var children = wait con.promise().query('select * from tâches où parentid = ' + taskId)
tâche[0][0].children = children[0].map(child => {
comp(enfant.id)
})
console.log(tâche[0])
}</pré>
<p>Mais cela renvoie une tâche avec des sous-tâches non définies : </p>
<pre class="brush:php;toolbar:false;">[
{
identifiant : 1,
tâche : 'Nettoyer l'appartement',
terminé : 0,
ID parent : nul,
créé par : 1,
créé le : 2022-03-23T23:47:33.000Z,
enfants : [ non défini, non défini ]
}
]≪/pré>
<p>En bref, ce que je veux, c'est ceci : </p>
<pre class="brush:php;toolbar:false;">{
identifiant : 1,
tâche : 'Nettoyer l'appartement',
terminé : 0,
ID parent : nul,
créé par : 1,
créé le : 2022-03-23T23:47:33.000Z,
enfants: [
{
identifiant : 2,
tâche : « Nettoyer la salle de bain »,
terminé : 0,
identifiant parent : 1,
créé par : 1,
créé le : 2022-03-23T23:47:33.000Z,
enfants: [
{
ID : 4,
tâche : 'laver la douche',
terminé : 0,
parent-identifiant : 2,
créé par : 1,
créé le : 2022-03-23T23:47:33.000Z,
enfants: [ ... ]
},
{
identifiant : 5,
tâche : « laver les toilettes »,
terminé : 0,
parent-identifiant : 2,
créé par : 1,
créé le : 2022-03-23T23:47:33.000Z,
enfants: [ ... ]
},
]
},
{
identifiant : 3,
tâche : « Nettoyer la cuisine »,
terminé : 0,
identifiant parent : 1,
créé par : 1,
créé le : 2022-03-23T23:47:33.000Z,
enfants: [ ... ]
},
}</pré>
<p>Des suggestions ? </p>
Vous attendez la fin de l'exécution des deux éléments attendus d'origine avant de démarrer le prochain appel récursif, puis d'imprimer sans attendre l'appel récursif lui-même.
Tout d'abord, vous avez besoin de
Mais il faut aussi attendre que chaque enfant ait fini de courir.
attendra que chaque promesse du tableau que vous lui transmettez soit complétée, tandis que
children[0].map(async () => {})
renverra un tableau de promesses. Continuez à attendre et ça devrait aller.En fait, le seul problème avec votre code est que vous n'attendez pas que la promesse soit résolue lorsque toutes les promesses du tableau de la fonction asynchrone
comp()
的结果。map()
将返回一个Promise数组,你需要等待所有这些Promise,可以使用Promise.all()
来实现。Promise.all()
返回一个Promise,当传递给Promise.all()
ont été résolues. Si vous l'attendez, votre tableau children sera propagé comme prévu.C'est le code utilisant
Promise.all()
. Comme je n'ai pas actuellement de base de données appropriée, j'ai remplacé tous les appels asynchrones de votre base de données par un appel asynchrone à une fonction avec un délai artificiel afin que vous puissiez voir comment les appels sont attendus et si les résultats sont réellement attendus. .