我刚刚开始玩angularJS,所以也许我问了一些容易做的事情,但我找不到办法做到这一点。 情况如下:我有一个由ng-repeat填充的列表,它取自一个范围控制器变量的值。这个变量在页面加载时通过jsonp调用进行加载,并且工作正常。 当我需要重新加载基于另一个选择的列表时,问题出现了。例如,如果select中的选择'day'值需要显示一些值,并且当我选择'week'时,我需要显示其他值(也通过ajax加载)。用angularjs重新加载一个列表
我试过的是有一个加载数据并返回它的服务,并且在控制器中有两个方法,一个用于第一个加载,另一个用于第二个方法,它使用变量$ scope.apply 。然后我调用第二个方法来改变选择值(我用jquery完成了它的简化,直到我可以修复它)。
这是我的HTML
<div x-ng-controller='LeaderboardCtrl'>
<select id='leaderboard-select'>
<option value='day'>day</option>
<option value='week'>week</option>
<option value='month'>month</option>
</select>
<div x-ng-repeat='p in leaderboard'>
<p>{{p}}</p>
</div>
</div>
的一部分,这是影响此功能
var lead = angular.module("lead",[]);
function LeaderboardCtrl($scope,$attrs,$http,jtlanService) {
$scope.leaderboard = [];
$scope.period = 'day';
var data = {
period:$scope.period
};
$scope.loadLeaderboard = function(){
myService.loadLeaderboard(data).then(function(leaderboard) {
$scope.leaderboard = [];
$scope.leaderboard.push.apply($scope.leaderboard,leaderboard);
});
}
$scope.reloadLeaderboard = function() {
myService.loadLeaderboard(data).then(function(leaderboard) {
$scope.$apply(function() {
$scope.leaderboard = [];
$scope.leaderboard.push.apply($scope.leaderboard,leaderboard);
});
});
}
$scope.loadLeaderboard()
}
lead.service("myService",["$http", function($http) {
var myService = {
loadLeaderboard : function(data) {
var promise = $http.jsonp("/widget/leaderboardJSONP?callback=JSON_CALLBACK&_="+new Date(),{
params:data,
cache:false,
ajaxOptions: { cache: false }
}).then(function(response) {
return response.data;
});
return promise;
}
};
return myService;
}]);
$("#leaderboard-select").change(function(){
scope.period = $("#leaderboard-select").val();
scope.reloadLeaderboard();
});
这里的部分代码与代码中的小提琴:http://jsfiddle.net/WFGqN/3/
。因为这个,你的小提琴现在有一个错误(检查控制台)。 – Langdon 2013-04-23 14:57:14
我已经更新了链接,现在我认为jquery也包含在小提琴 – Eylen 2013-04-23 15:01:51