AngularJS异步问题如何从另一个组件中加载数据?
创始人
2024-10-27 13:30:17
0

在AngularJS项目中,可以通过以下两种方法从另一个组件中加载数据:

  1. 使用服务: 创建一个服务,用于在不同的组件之间共享数据。在需要加载数据的组件中注入这个服务,并调用其方法获取数据。

// Service angular.module('myApp').service('dataService', function($http) { var data = {};

this.getData = function() { return $http.get('/api/data').then(function(response) { data = response.data; }); };

this.getDataInService = function() { return data; }; });

// Component A angular.module('myApp').component('componentA', { templateUrl: 'componentA.html', controller: function(dataService) { var ctrl = this;

ctrl.$onInit = function() {
  dataService.getData().then(function() {
    ctrl.data = dataService.getDataInService();
  });
};

} });

// Component B angular.module('myApp').component('componentB', { templateUrl: 'componentB.html', controller: function(dataService) { var ctrl = this;

ctrl.data = {};

dataService.getData().then(function() {
  ctrl.data = dataService.getDataInService();
});

} });

  1. 使用事件广播: 在加载数据的组件中,使用$scope.$broadcast()方法广播一个事件,另一个组件可以通过$scope.$on()方法监听这个事件并获取数据。

// Component A angular.module('myApp').component('componentA', { templateUrl: 'componentA.html', controller: function($scope) { var ctrl = this;

$scope.$on('dataLoaded', function(event, data) {
  ctrl.data = data;
});

} });

// Component B angular.module('myApp').component('componentB', { templateUrl: 'componentB.html', controller: function($http, $scope) { var ctrl = this;

ctrl.loadData = function() {
  $http.get('/api/data').then(function(response) {
    $scope.$broadcast('dataLoaded', response.data);
  });
};

ctrl.loadData();

} });

相关内容

热门资讯

透明总结!新玄龙斗牛卡牌,we... 新玄龙斗牛卡牌开挂教程视频分享装挂详细步骤在当今的网络游戏中,新玄龙斗牛卡牌作为一种经典的娱乐方式,...
重大通报!聚财app辅助,葫芦... 重大通报!聚财app辅助,葫芦娃通杀辅助使用(有挂开挂辅助插件)这是一款可以让一直输的玩家,快速成为...
透视线上!随意玩辅助器视频透视... 透视线上!随意玩辅助器视频透视挂,aapoker脚本-原先有挂开挂辅助器您好:随意玩辅助器视频透视挂...
实操分享!中至余干小程序破解,... 【亲,中至余干小程序破解 这款游戏可以开挂的,确实是有挂的,很多玩家在这款中至余干小程序破解中打牌都...
透视脚本!温州茶苑手机辅助器,... 您好:温州茶苑手机辅助器这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的...
详细说明!微信小程序财神破解版... 您好:微信小程序财神破解版这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户...
玩家必看科普!全民牛牛拼三张开... 全民牛牛拼三张开挂是一款专注玩家量身打造的游戏记牌类型软件,在全民牛牛拼三张开挂这款游戏中我们可以记...
透视脚本!新卡农辅助软件,hh... 透视脚本!新卡农辅助软件,hhpoker德州机器人-固有有挂开挂辅助平台;无需打开直接搜索打开薇:1...
重大通报!开心泉州小程序辅助哪... 重大通报!开心泉州小程序辅助哪里查看,新道游辅助器(有挂开挂辅助器);无需打开直接搜索薇:13670...
透视软件!四川血战到底攻略,h... 透视软件!四川血战到底攻略,hhpoker可以控制牌吗-原先有挂开挂辅助脚本;无需打开直接搜索加(薇...