我正在尝试让 $rootScope.$broadcast 刷新我的视图。该服务是-
var app = angular.module("productsApp", [])
.service("serviceProvider", function ($http) {
this.getDatas = function getDatas(data) {
return $http({
method: 'POST', url: serviceUrl + '/GetProductsByCategoryOrName', headers: {
'Authorization': apiKey
},
data: data
})
}
return this
}).factory("sharedService", function ($rootScope) {
var mySharedService = {};
mySharedService.values = [];
mySharedService.passData = function (newData) {
mySharedService.values = newData;
$rootScope.$broadcast('dataPassed', newData);
}
return mySharedService;
});
通过控制器调用-
function searchProductsController($scope, $window, serviceProvider, sharedService) {
$scope.submit = function () {
var data = { "query": $scope.searchText, "categoryId": "976759", "pageIndex": 0, "sortDirection": "asc" };
serviceProvider.getDatas(data).then(function (response) {
var result = response;
sharedService.passData(result.data.data);
});
}
};
在此控制器sharedService.passData
中,它将新数组传递给服务方法。然后它试图用这条线来广播它的变化—— $rootScope.$broadcast('dataPassed', newData)
我不知道为什么它不广播要查看的更改。有没有其他方法可以广播更改?
注意- 我之前的问题如何在控制器之间传输数据无法为我提供任何帮助。
编辑
到目前为止,我已经改变了听众——
mySharedService.passData = function (newData) {
$rootScope.$broadcast('dataPassed', newData)
}
$rootScope.$on('dataPassed', function (newData) {
mySharedService.values = newData;
})
但仍然无法刷新视图。