54 votes

angular - accès aux données de plusieurs appels http - comment résoudre les promesses

Je suis coincé sur quelque chose, je pense, devrait être simple. J'ai besoin de prendre des données à partir de trois différents appels ajax, de combiner et de traiter tous les trois, et afficher le tableau qui en résulte pour l'utilisateur.

Dans sa forme la plus simple de mon code ressemble à ceci:

function giftControler ($scope, $http) {
  var names = $http.get("names.json"),
      naughty = $http.get("naughty.json"),
      nice = $http.get("nice.json");

Je comprends que mes variables sont affectées à des promesses, pas de résultats, et que la requête http a été transmise à la file d'attente des événements. Si je suis avec ces instructions exécutables de ces variables sera pas défini. Je ne comprends pas comment attendre de ces promesses à résoudre afin de poursuivre leur traitement.

Ce que je voudrais faire est d'ajouter immédiatement le code:

      for (var i=0; i<names.length; i++){
        for (var j=0; j<nice.length; j++){
          if (names[i] === nice[j]){
            names[i] = names[i] + "--Yay!!";
          };
        };
      };                
      $scope.kids = names;

Le problème est que je ne peux pas travailler hors de promesses, comme s'ils étaient résolus de tableaux. Javascript, voir ces déclarations à droite après le http appels et de les exécuter immédiatement, même si les promesses n'ont pas été résolus.

Où je suis coincé, c'est que le $http-api est de me donner une promesse objet avec trois fonctions: l'erreur, le succès, alors. Je ne suis pas sûr de quoi faire avec dans ce cas. J'ai besoin d'un seul succès fonctionner pour tous les trois. J'ai besoin de tous les trois à résoudre, puis traiter les données dans chaque, puis d'affecter le résultat à une angulaires du modèle.

Je suis sûr que je suis absent quelque chose d'évident, mais quelqu'un aurait-il une suggestion? Dans mon travail, j'ai plusieurs appels ajax de multiples sources de données et beaucoup de traitement (comparaison de valeurs, le tri, la concaténation, etc) pour arriver à une bonne collecte de données, mais je ne peux pas obtenir passé ce problème.

Merci,

156voto

Valentyn Shybanov Points 8483

Vous pouvez utiliser la fonction 'tous' de $ q:

 function giftControler ($scope, $http, $q) {
  var names = $http.get("names.json"),
      naughty = $http.get("naughty.json"),
      nice = $http.get("nice.json");
  $q.all([names, naughty,nice]).then(function(arrayOfResults) { 
      ... This callback would be called when all promised would be resolved
    });
 

Cette façon est un peu plus propre.

Voici un lien vers docementation: http://docs.angularjs.org/api/ng.$q

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X