我已经为 Chosen 和 Angular 学习了这个很棒的教程(链接)(代码几乎相同)
这是我的指令:
app.angularModule.directive('chosen', function() {
var linker = function (scope, element, attrs) {
var list = attrs['chosen'];
scope.$watch(list, function () {
element.trigger('chosen:updated');
});
element.chosen({ width: '350px'});
};
return {
restrict: 'A',
link: linker
};
});
这是html:
<select data-placeholder="Choose a Category" multiple class="col-lg-8 chosen-select" chosen="items"
ng-options="item._backingStore.Name for item in items" ng-model="selectedCategories" >
</select>
我想要的是,当用户单击编辑按钮时,会弹出模式窗口,并且在模式窗口中选择在单击编辑按钮之前选择的类别。
这是控制器的那一部分:
$scope.$watch(function() { return adminCrudService.getCategoriesForUpdate(); }, function() {
$scope.action = "edit";
$scope.categoriesForUpdate = adminCrudService.getCategoriesForUpdate();
if ($scope.categoriesForUpdate.length > null) {
$scope.selectedCategories = _.filter($scope.items, function (item) {
return _.contains($scope.categoriesForUpdate, item);
});
}
});
我已经记录 了 $scope.selectedCategories并且一切都很好,但是由于某种原因,在选择中没有选择任何内容。
那么我做错了什么,我该如何解决呢?
编辑
我注意到当我选择一些项目时,关闭模式,再次打开它,即使我把这条线放在 $watch 中,选定的值仍然存在
$scope.selectedCategories = "";
编辑 2
所以我暂时搁置了这个问题,因为我有更重要的事情要处理。我试过没有选择,即使用“正常”选择和代码工作。所以绝对我选择的指令不能正常工作。