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();

} });

相关内容

热门资讯

来临!广西老友玩有破解码!竟然... 来临!广西老友玩有破解码!竟然真的有辅助神器(有挂规律)-哔哩哔哩广西老友玩有破解码是不是有人用挂微...
事发当天!情怀蒲仙辅助!果然有... 事发当天!情怀蒲仙辅助!果然有挂辅助脚本(讲解有挂)-哔哩哔哩1、下载好情怀蒲仙辅助透视辅助下载之后...
今年以来!广东闲来辅助工具!竟... 今年以来!广东闲来辅助工具!竟然真的有辅助下载(有挂技术)-哔哩哔哩进入游戏-大厅左侧-新手福利-激...
受玩家影响!多乐辅助器!本来真... 受玩家影响!多乐辅助器!本来真的有辅助插件(有挂规律)-哔哩哔哩所有人都在同一条线上,像星星一样排成...
昨日!土豪联盟辅助!总是真的有... 昨日!土豪联盟辅助!总是真的有辅助下载(有挂分析)-哔哩哔哩;1)土豪联盟辅助免费钻石:进一步探索土...
为了进一步!三哥玩外g挂!都是... 为了进一步!三哥玩外g挂!都是有挂辅助挂(新版有挂)-哔哩哔哩1)三哥玩外g挂有没有挂:进一步探索三...
据公告内容!越乡游辅助软件!原... 据公告内容!越乡游辅助软件!原来真的有辅助脚本(有人有挂)-哔哩哔哩运越乡游辅助软件辅助工具,进入游...
记者获悉!皮皮游戏辅助平台!其... 记者获悉!皮皮游戏辅助平台!其实是有辅助软件(果真有挂)-哔哩哔哩皮皮游戏辅助平台辅助器是一种具有地...
今天下午!家乡大贰祈福有用吗!... 今天下午!家乡大贰祈福有用吗!其实是真的辅助安装(有挂总结)-哔哩哔哩1、起透看视 家乡大贰祈福有用...
此事迅速冲上热搜!天天卡五星攻... 此事迅速冲上热搜!天天卡五星攻略!果然真的有辅助工具(有挂猫腻)-哔哩哔哩天天卡五星攻略脚本下载中分...