我已经阅读了一些与此主题有关的问题,无法弄清楚我在自己的方向上缺少什么。
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!
答案 0 :(得分:3)
你如何使用该指令? 根据定义,您需要具有两个属性&#34; value&#34;和&#34; ng-model&#34;组。 例如:
<number-picker value="xyz" ng-model="abc"></number-picker>
错误&#34;表达式&#39; undefined&#39;与指令一起使用...&#34;如果未设置其中一个范围值,则通常会抛出此值。