我在将我的选择元素的选项列表中的项目设置为选中时遇到问题。我的服务器后端是 Django 1.5,以 TastyPie 作为 API。
模板(简化)
<select
ng-model='dataService.major_minor.department'
ng-options='d.name for d in dataService.departments'
name='department'
class='select2'
required>
</select>
数据服务
majorMinor.factory('dataService', function($rootScope, Restangular) {
var self = {};
self.degrees = [];
self.departments = [];
self.major_minor = false;
self.majors_and_minors = [];
self.fetch_degrees = function() {
Restangular.all('degree').getList().then(function(results) {
self.degrees = results;
});
};
self.fetch_departments = function() {
Restangular.all('department').getList().then(function(results) {
self.departments = results;
});
};
self.fetch_major_minor = function(majorMinorID) {
Restangular.one('major-minor', majorMinorID).get().then(function(result) {
self.major_minor = result;
});
};
self.fetch_major_minor_list = function() {
Restangular.all('major-minor').getList().then(function(results) {
self.majors_and_minors = results;
});
};
self.fetch_degrees();
self.fetch_departments();
self.fetch_major_minor_list();
return self;
});
控制器
majorMinor.controller('EditCtrl',
function($scope, $routeParams, dataService) {
$scope.dataService = dataService;
$scope.dataService.major_minor = false;
$scope.dataService.fetch_major_minor($routeParams.majorMinorID);
}
);
我正在努力解决的问题是 major_minor.department 是一个外键。TastyPie 正在返回一个完整的对象,因此它不仅仅是部门 URI。dataService.departments 数组是该用户可用的所有部门的数组。如果要将major_minor.department 与dataService.departments[indexOfDepartment] 进行比较,它们将是相等的。
有什么想法为什么 ng-model 没有正确选择 ng-option?我对 Angular/Restangular 的理解可能存在差距,因为这只是我使用两者的第二个项目。