Maison > Questions et réponses > le corps du texte
Description du scénario commercial :
Supposons que dans le contrôleur enfant, les différentes opérations de clic de l'utilisateur seront divisées en deux événements, qui seront diffusés au contrôleur parent par le contrôleur
$scope.$emit('ngUserLogin');
$scope.$emit('ngUserUpdate');
Dans le contrôleur parent, nous utilisons $on pour écouter ces deux événements
.$scope.$on('ngUserlogin', function(){"}
$scope.$on('ngUserUpload', function(){"}
Mais dans une certaine scène, j'ai trouvé que ces deux événements exécutaient la même logique, alors j'ai voulu l'écrire comme ceci :
$scope.$on(['ngUserlogin','ngUserUpload'], function(){"}
C'est le mode auquel je m'attendais, mais ng ne peut évidemment pas être écrit comme ça. Je voudrais vous demander comment surveiller plus de deux événements en même temps dans votre entreprise actuelle
黄舟2017-05-15 17:05:07
Malheureusement, ng
n'a pas le mode que vous attendiez. Pour faire une petite astuce, vous pouvez écrire comme ceci :
angular.forEach(['ngUserlogin','ngUserUpload'], function(value){
$scope.$on(value, function(event){
console.log(event.name);//执行你想要的吧
});
});
phpcn_u15822017-05-15 17:05:07
Vous pouvez changer d'avis, vous n'envoyez qu'un seul événement, puis apportez différents paramètres lors de l'envoi de cet événement$emit(name, args);
lorsque vous écouterez cet événement, jugez le paramètre, et vous saurez ce que vous allez faire ensuite ; .