我正在开发一个使用 AngularJS 作为框架的移动应用程序,目前我有一个与此类似的结构:
app.config(['$routeProvider', function($routeProvider) {
$routeProvider
.when('/', {
templateUrl : 'pages/home.html',
controller : 'homeCtrl'
})
.when('/one', {
templateUrl : 'pages/one.html',
controller : 'oneCtrl'
})
.when('/two', {
templateUrl : 'pages/two.html',
controller : 'twoCtrl'
});
}]);
app.controller('homeCtrl', ['$scope', function($scope) {
}]);
app.controller('oneCtrl', ['$scope', function($scope) {
}]);
app.controller('twoCtrl', ['$scope', function($scope) {
}]);
然后我用一个显示内容ng-view
:
<div class="ng-view></div>
一切运行良好,但我需要从 JSON 文件加载数据以填充应用程序的所有内容。我想要的是进行 AJAX 调用只有一次然后通过我所有不同的控制器传递数据。在我的第一次尝试中,我想创建一个带有$http.get()
并将其包含在每个控制器中,但它不起作用,因为每次我注入和使用该服务时它都会发出不同的 ajax 请求。由于我是新使用角度的,所以我想知道什么是最好的方法或更“角度的方法”来实现这一点而不搞乱它。
Edit:我正在添加服务的代码,这只是一个简单的$http.get
要求:
app.service('Data', ['$http', function($http) {
this.get = function() {
$http.get('data.json')
.success(function(result) {
return result;
})
}
});