Angular Number Picker指令表达式未定义

时间:2016-02-11 16:04:24

标签: angularjs numbers undefined directive picker

我已经阅读了一些与此主题有关的问题,无法弄清楚我在自己的方向上缺少什么。

angular.module('app')
    .directive('numberPicker', [NumberPicker]);

function NumberPicker () {

    var getTarget, getType;

    getTarget = function (e) { return angular.element(e.target); }

    getType = function (e) { return getTarget(e).attr('direction-type'); }

    return {
        restrict: 'E',
        replace: true,
        require: 'ngModel',
        scope: {
            value: '='
        },
        template: '<div class="ui action input">' +
                    '<input value="{{value}}" type="text" />' +
                    '<button class="ui icon button" type="button" direction-type="up" ng-class="{disabled : canUp === false}">' +
                        '<i class="angle up icon" direction-type="up"></i>' +
                    '</button>' +
                    '<button class="ui icon button" type="button" direction-type="down" ng-class="{disabled : canDown === false}">' +
                        '<i class="angle down icon" direction-type="down"></i>' +
                    '</button>' +
                  '</div>',
        controller: function ($scope) {},
        link: function (scope, element, attrs, ctrl) {

            scope.value = 0;

            var options = {
                min: 0,
                max: 10,
                step: 1
            };

            scope.$watch('value', function (newValue) {
                scope.canDown = newValue > options.min;
                scope.canUp = newValue < options.max;

                if (ctrl.$viewValue != newValue) {
                    ctrl.$setViewValue(newValue);
                }
            });

            var changeNumber = function (event) {
                var type = getType(event);
                if ('up' === type) {
                    if (scope.value >= options.max) {
                        return;
                    }
                    scope.value += options.step;
                }
                if ('down' === type) {
                    if (scope.value <= options.min) {
                        return;
                    }
                    scope.value -= options.step;
                }
            }

            var btn = element.find('button');
            var input = element.find('input');

            btn.on('click', function (e) {

                scope.$apply(function () {
                    changeNumber(e);
                });

                e.preventDefault();
            });

            input.on('change', function (e) {
                scope.value = input[0].value;
                scope.$apply();
            })

            scope.$on('$destroy', function () {
                btn.off('touchstart touchend click')
            });
        }
    }
}

这样做的目的是为Semantic UI创建一个数字选择器表单元素。几天前它完美地工作了。而这个错误是如此模糊,我甚至无法处理从哪里开始。我是否提到我是一名Angular noob?

错误是:

Error: [$compile:nonassign] Expression 'undefined' used with directive 'numberPicker' is non-assignable!

1 个答案:

答案 0 :(得分:3)

你如何使用该指令? 根据定义,您需要具有两个属性&#34; value&#34;和&#34; ng-model&#34;组。 例如:

<number-picker value="xyz" ng-model="abc"></number-picker>

错误&#34;表达式&#39; undefined&#39;与指令一起使用...&#34;如果未设置其中一个范围值,则通常会抛出此值。