8

我已经为 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

所以我暂时搁置了这个问题,因为我有更重要的事情要处理。我试过没有选择,即使用“正常”选择和代码工作。所以绝对我选择的指令不能正常工作。

4

2 回答 2

11

我已经解决了,解决方案实际上非常简单明了(当您了解 Angular 指令的工作方式时)。这是指令的完整代码:

app.angularModule.directive('chosen', function() {
    var linker = function (scope, element, attrs) {
        var list = attrs['chosen'];

        scope.$watch(list, function () {
            element.trigger('chosen:updated');
        });

        scope.$watch(attrs['ngModel'], function() {
            element.trigger('chosen:updated');
        });

        element.chosen({ width: '350px'});
    };

    return {
        restrict: 'A',
        link: linker
    };
});
于 2013-09-01T11:45:53.093 回答
1

对先前解决方案的更多扩展版本的评论。与作者相同,在 HTML 标记中,我提供了类似的源集合chosen="vm.myCollection",实际上使用正则表达式解析ng-optionsng-repeat属性更好,也许稍后会。与 OP 相比,我将 $watchCollection 用于数组,并在作用域即将销毁时调用 unwatches。

(function () {
    'use strict';
    angular.module('common.directives').directive('chosen', enterPressDirective);

    function enterPressDirective() {
        return {
            restrict: 'A',
            link: function (scope, elm, attrs) {
                var unwatchModel = scope.$watch(attrs.ngModel, function () {
                    elm.trigger('chosen:updated');
                });

                var unwatchSource = scope.$watchCollection(attrs.chosen, function () {
                    elm.trigger('chosen:updated');
                });

                elm.chosen();

                scope.$on('$destroy', function () {
                    unwatchModel();
                    unwatchSource();
                });
            }
        };
    }
}());
于 2015-08-21T14:02:46.880 回答