gpt4 book ai didi

angularjs - $parsers 不处理空格

转载 作者:行者123 更新时间:2023-12-03 06:42:17 24 4
gpt4 key购买 nike

我有一个服装指令来设置 % 的事物,例如:- 快乐:[ 90 ]- 悲伤:[10]

所以它只能允许 1 到 100。所以我不想允许任何字符等。我知道我可以使用 ng-pattern 等。但我不希望他们甚至添加一个字符,所以我必须要做的。

它有效,但我遇到的问题是空格不会触发 $parsers,是否有解决方法可以用空格触发它?

app.directive('numericOnly', function(){
return {
require: 'ngModel',
link: function(scope, element, attrs, modelCtrl) {
modelCtrl.$parsers.push(function (inputValue) {

//Remove all non numeric values
var transformedInput = inputValue.replace(/\D/g,'');

//Remove all spaces
transformedInput = transformedInput.replace(/\s/g, "");

//Remove any leading zero
if(transformedInput.substring(0,1) === '0') {
console.log('is zero');
if(transformedInput.length === 1) {
transformedInput = '';
} else {
transformedInput = transformedInput.substring(1, transformedInput.length);
}
}

//Make sure it is not over 100
var numberCopy = parseInt(transformedInput);
if(!isNaN(numberCopy)){
if(numberCopy > 100) {
console.log('bigger than 100');
numberCopy = 100;
transformedInput = String(numberCopy);
}
}

//If changes done, then update modelCtrl
if (transformedInput!=inputValue) {
modelCtrl.$setViewValue(transformedInput);
modelCtrl.$render();
}

//Return
return transformedInput;
});
}
};
});

骗子:http://plnkr.co/edit/oKXExZ8lkHzUSqHKpm1n?p=preview

最佳答案

Angular 默认情况下会修剪 ngModel 值。所以你需要添加ng-trim指令输入元素,它不允许字符串两侧有空格。

<input type="text" numeric-only="" ng-trim="false" ng-model="nyNumber"/>

你不再需要这行了

//Remove all spaces
transformedInput = transformedInput.replace(/\s/g, "");

关于angularjs - $parsers 不处理空格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27175374/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com