angularjs:仅允许在文本框中键入数字


68

在angularjs中,有任何可用的功能,仅允许将数字键入文本框中,例如


10
使用<input ng-pattern =“ \ d *” ... />
Tamil Selvan C

它是在提交validation.works的form.i要禁止用户输入任何其他值比数/ integer..like这 texotela.co.uk/code/jquery/numeric
阿里·哈桑

Answers:


26

此功能正是您所需要的。http://docs.angularjs.org/api/ng.directive:input.number

编辑:

您可以将jquery插件包装到指令中。我在这里创建了一个示例:http : //jsfiddle.net/anazimok/jTJCF/

HTML:

<div ng-app="myApp">
    <div>
        <input type="text" min="0" max="99" number-mask="" ng-model="message">
            <button ng-click="handleClick()">Broadcast</button>
    </div>

</div>

CSS:

.ng-invalid {
    border: 1px solid red;
}

JS:

// declare a module
var app = angular.module('myApp', []);

app.directive('numberMask', function() {
    return {
        restrict: 'A',
        link: function(scope, element, attrs) {
            $(element).numeric();
        }
    }
});

16
OP并没有完全要求。您的解决方案可以提供输入验证(即,当检测到非数字时显示错误),但是用户仍然可以在文本框中键入非数字。
tamakisquare

1
@AliHasan这不应该是正确的答案,因为它不能回答问题。
时段

65

此代码显示了如何防止输入非数字符号的示例。

angular.module('app').
  directive('onlyDigits', function () {

    return {
        restrict: 'A',
        require: '?ngModel',
        link: function (scope, element, attrs, modelCtrl) {
            modelCtrl.$parsers.push(function (inputValue) {
                if (inputValue == undefined) return '';
                var transformedInput = inputValue.replace(/[^0-9]/g, '');
                if (transformedInput !== inputValue) {
                    modelCtrl.$setViewValue(transformedInput);
                    modelCtrl.$render();
                }
                return transformedInput;
            });
        }
    };
});

1
谢谢你 我简化了非数字剥离,并编写了一个测试:gist.github.com/henrik/769d49136744ddcaa1dc在编写本文时,代码是JS,而测试是CoffeeScript。我认为,很快两者都将成为CoffeeScript。
Henrik N

双击字母键将使此操作失败
Blowsie 2015年

7
正如Blowsie指出的那样,此代码并非在所有情况下均有效。.这是一个有效的jsfiddle,我正尝试更新此答案以使用:jsfiddle.net/thomporter/DwKZh
Ryan Langton

1
如果您要显式禁用空格输入,则该指令应与ng-trim = false一起使用
永恒

用户可以键入空格。attrs.$set('ngTrim', "false");在解析器前添加以防止出现空格。
艾哈迈德·帕扬

42

的HTML

 <input type="text" name="number" only-digits>

//只需输入123

  .directive('onlyDigits', function () {
    return {
      require: 'ngModel',
      restrict: 'A',
      link: function (scope, element, attr, ctrl) {
        function inputValue(val) {
          if (val) {
            var digits = val.replace(/[^0-9]/g, '');

            if (digits !== val) {
              ctrl.$setViewValue(digits);
              ctrl.$render();
            }
            return parseInt(digits,10);
          }
          return undefined;
        }            
        ctrl.$parsers.push(inputValue);
      }
    };
});

//输入:123或123.45

 .directive('onlyDigits', function () {
    return {
      require: 'ngModel',
      restrict: 'A',
      link: function (scope, element, attr, ctrl) {
        function inputValue(val) {
          if (val) {
            var digits = val.replace(/[^0-9.]/g, '');

            if (digits.split('.').length > 2) {
              digits = digits.substring(0, digits.length - 1);
            }

            if (digits !== val) {
              ctrl.$setViewValue(digits);
              ctrl.$render();
            }
            return parseFloat(digits);
          }
          return undefined;
        }            
        ctrl.$parsers.push(inputValue);
      }
    };
 });

2
您的第二个示例(//类型:123或123.45)允许输入多个小数位,例如11.22..33 ..... 444将返回有效。
Paul McClean 2015年

2
我认为如果(digits.split('。')。length> 2)digits = digits.substring(0,digits.length-1);
马特2015年

1
为什么对于相同的要求在普通javascript中很简单的情况下,为什么angularjs中的代码就这么长?
kittu 2015年

如何将其限制为仅两位数?
巴拉斯

@Bharath仅限制2个小数--如果(digits.split('。')。length> 1){digits = digits.substring(0,digits.indexOf('。')+ 3); }
Aravinthan K '18

38

我只是在指令中使用ng-keypress输入。

HTML:

<input type="text" ng-keypress="filterValue($event)"/>

JS:

$scope.filterValue = function($event){
        if(isNaN(String.fromCharCode($event.keyCode))){
            $event.preventDefault();
        }
};

2
虽然这并不是真正的“成角度的方式”,但似乎是防止用户输入的相对安全的选择
Blowsie

4
这似乎很简单,尽管非角度方式可能会停止一些工作,但我绝对喜欢这种方法。必须添加必须允许的其他2种情况,event.which === 8和event.which === 46(分别用于退格和删除)
Markiv

不错的解决方案!我使用@Markiv注释在一个允许版本,提交和导航的新答案中改进了您的代码。
Leopoldo Sanczyk '16

我喜欢这种解决方案,尽管将值修整了=>我稍微改变了条件以防止按下空格键:if(isNaN(String.fromCharCode($ event.keyCode))|| $ event.keyCode === 32 )
Dimi

不推荐使用按键事件,某些浏览器(即Chrome)不支持该事件。Keydown事件也很糟糕-在某些设备上,Nexus4无法报告正确的密钥代码。做到这一点的唯一真实方法(afaik)是不使用字符,而是使用实际的真实文本。
Erti-Chris Eelmaa

21

这是最简单,最快的方法,仅允许输入数字。

<input type="text" id="cardno" placeholder="Enter a Number" onkeypress='return event.charCode >= 48 && event.charCode <= 57' required>

谢谢


如果您可以将其放入指令中,那将是完美的
WtFudgE

1
退格和删除也将不起作用-)需要添加其他检查
igorGIS '16

2
问题是仅允许数字输入,如果您想要更多,那么当然可以相应地对其进行自定义。因此,这只是一个建议,并非对所有问题的具体答案。
Sijan Gurung

我认为这是命运的方法
理查德·阿奎尔

7

为了进一步了解安东的答案-

angular.module("app").directive("onlyDigits", function ()
{
    return {
        restrict: 'EA',
        require: '?ngModel',
        scope:{
            allowDecimal: '@',
            allowNegative: '@',
            minNum: '@',
            maxNum: '@'
        },

        link: function (scope, element, attrs, ngModel)
        {
            if (!ngModel) return;
            ngModel.$parsers.unshift(function (inputValue)
            {
                var decimalFound = false;
                var digits = inputValue.split('').filter(function (s,i)
                {
                    var b = (!isNaN(s) && s != ' ');
                    if (!b && attrs.allowDecimal && attrs.allowDecimal == "true")
                    {
                        if (s == "." && decimalFound == false)
                        {
                            decimalFound = true;
                            b = true;
                        }
                    }
                    if (!b && attrs.allowNegative && attrs.allowNegative == "true")
                    {
                        b = (s == '-' && i == 0);
                    }

                    return b;
                }).join('');
                if (attrs.maxNum && !isNaN(attrs.maxNum) && parseFloat(digits) > parseFloat(attrs.maxNum))
                {
                    digits = attrs.maxNum;
                }
                if (attrs.minNum && !isNaN(attrs.minNum) && parseFloat(digits) < parseFloat(attrs.minNum))
                {
                    digits = attrs.minNum;
                }
                ngModel.$viewValue = digits;
                ngModel.$render();

                return digits;
            });
        }
    };
});

1
ngModel.$viewValue = digits您应该使用ngModel.$setViewValue(digits)ngModelController和ngForm钩子的其余部分,而不是使用它。我需要它,因为这是必填字段,当我输入字母(未显示)时,表格被标记为有效-错误。
Chaz 2015年

该指令的问题是,如果您键入合法数字,并且错误地键入字母,则将删除字段。
orikoko

7

我的解决方案接受“复制粘贴”并保存插入符号的位置。它用于产品成本,因此仅允许使用正十进制值。可以很容易地重构,以允许负数或整数。

angular
        .module("client")
        .directive("onlyNumber", function () {
            return {
                restrict: "A",
                link: function (scope, element, attr) {
                    element.bind('input', function () {
                        var position = this.selectionStart - 1;

                        //remove all but number and .
                        var fixed = this.value.replace(/[^0-9\.]/g, '');  
                        if (fixed.charAt(0) === '.')                  //can't start with .
                            fixed = fixed.slice(1);

                        var pos = fixed.indexOf(".") + 1;
                        if (pos >= 0)               //avoid more than one .
                            fixed = fixed.substr(0, pos) + fixed.slice(pos).replace('.', '');  

                        if (this.value !== fixed) {
                            this.value = fixed;
                            this.selectionStart = position;
                            this.selectionEnd = position;
                        }
                    });
                }
            };
        });

放在html页面上:

<input type="text" class="form-control" only-number ng-model="vm.cost" />

2

这是对我有效的方法。它的总部设在samnau anwser但允许提交与形式ENTER,增加和减少与数字UPDOWN箭头用,编辑DELBACKSPACELEFTRIGHT,然后导航槽与领域TAB。请注意,它适用于正整数,例如金额。

HTML:

<input ng-keypress="onlyNumbers($event)" min="0" type="number" step="1" ng-pattern="/^[0-9]{1,8}$/" ng-model="... >

ANGULARJS:

$scope.onlyNumbers = function(event){   
    var keys={
        'up': 38,'right':39,'down':40,'left':37,
        'escape':27,'backspace':8,'tab':9,'enter':13,'del':46,
        '0':48,'1':49,'2':50,'3':51,'4':52,'5':53,'6':54,'7':55,'8':56,'9':57
    };
    for(var index in keys) {
        if (!keys.hasOwnProperty(index)) continue;
        if (event.charCode==keys[index]||event.keyCode==keys[index]) {
            return; //default event
        }
    }   
    event.preventDefault();
};

2

基于djsiz解决方案,包装在指令中。注意:它不会处理数字,但可以轻松更新

angular
        .module("app")
        .directive("mwInputRestrict", [
            function () {
                return {
                    restrict: "A",
                    link: function (scope, element, attrs) {
                        element.on("keypress", function (event) {
                            if (attrs.mwInputRestrict === "onlynumbers") {
                                // allow only digits to be entered, or backspace and delete keys to be pressed
                                return (event.charCode >= 48 && event.charCode <= 57) ||
                                       (event.keyCode === 8 || event.keyCode === 46);
                            }
                            return true;
                        });
                    }
                }
            }
        ]);

的HTML

 <input type="text"
        class="form-control"
        id="inputHeight"
        name="inputHeight"
        placeholder="Height"
        mw-input-restrict="onlynumbers"
        ng-model="ctbtVm.dto.height">


1

您可以检查 https://github.com/rajesh38/ng-only-number

  1. 键入时,它将输入限制为文本框中的数字和小数点。
  2. 您可以限制小数点前后的位数
  3. 如果从文本框中删除了小数点,它还会修剪小数点后的数字,例如,如果您放置了123.45,然后删除了小数点,它也会删除小数点后的尾数并将其设为123。

1

您可以执行以下操作:将ng-pattern与RegExp“ / ^ [0-9] + $ / ”一起使用,这意味着仅整数有效。

<form novalidate name="form">
    <input type="text" data-ng-model="age" id="age" name="age" ng-pattern="/^[0-9]+$/">
    <span ng-show="form.age.$error.pattern">The value is not a valid integer</span>
</form>

1

该解决方案将仅接受数字“。”。和“-”

这也限制了文本框中的空格输入。我曾经使用该指令来实现相同的目的。

请在以下工作示例中找到解决方案。

http://jsfiddle.net/vfsHX/2697/

HTML:

<form ng-app="myapp" name="myform" novalidate> 
<div ng-controller="Ctrl">
<input name="number" is-number ng-model="wks.number">
<span ng-show="!wks.validity">Value is invalid</span>
</div>

JS:

var $scope;
var app = angular.module('myapp', []);

app.controller('Ctrl', function($scope) {
    $scope.wks =  {number: 1, validity: true}
});

app.directive('isNumber', function () {
    return {
        require: 'ngModel',
        link: function (scope, element, attrs, ngModel) {   
        element.bind("keydown keypress", function (event) {
          if(event.which === 32) {
            event.returnValue = false;
            return false;
          }
       }); 
            scope.$watch(attrs.ngModel, function(newValue,oldValue) {
                var arr = String(newValue).split("");
                if (arr.length === 0) return;
                if (arr.length === 1 && (arr[0] == '-' || arr[0] === '.' )) return;
                if (arr.length === 2 && newValue === '-.') return;
                if (isNaN(newValue)) {
                    //scope.wks.number = oldValue;
                    ngModel.$setViewValue(oldValue);
                                    ngModel.$render();
                }
            });

        }
    };
});

1

简单易懂。只需复制粘贴此代码即可解决您的问题。对于更多情况,只需更改pattern中的值即可完成工作。

<input type="text"  pattern="[0-9]{0,}" oninvalid="this.setCustomValidity('Please enter only numeric value. Special character are not allowed.')" oninput="setCustomValidity('')">


0

我有一个类似的问题,并最终引起了钩子和事件

ng-change="changeCount()" 

然后:

self.changeCount = function () {
      if (!self.info.itemcount) {
        self.info.itemcount = 1;
      }
 };

因此,如果插入了无效数字,则用户默认为1。


0

我在这里加了jQuery

.directive('numbersCommaOnly', function(){
   return {
     require: 'ngModel',
     link: function (scope, element, attrs, ngModel) {

        element.on('keydown', function(event) {                  
            // Allow: backspace, delete, tab, escape, enter and .
            var array2 = [46, 8, 9, 27, 13, 110, 190]
            if (array2.indexOf(event.which) !== -1 ||
                 // Allow: Ctrl+A
                (event.which == 65 && event.ctrlKey === true) ||
                 // Allow: Ctrl+C
                (event.which == 67 && event.ctrlKey === true) ||
                 // Allow: Ctrl+X
                (event.which == 88 && event.ctrlKey === true) ||
                 // Allow: home, end, left, right
                (event.which >= 35 && event.which <= 39)) {
                     // let it happen, don't do anything
                     return;
            }
            // Ensure that it is a number and stop the keypress
            if ((event.shiftKey || (event.which < 48 || event.which > 57)) && (event.which < 96 || event.which > 105)) {
                event.preventDefault();
            }
         });

     }
   };
})

0
 <input type="text" ng-keypress="checkNumeric($event)"/>
 //inside controller
 $scope.dot = false
 $scope.checkNumeric = function($event){
 if(String.fromCharCode($event.keyCode) == "." && !$scope.dot){
    $scope.dot = true
 }
 else if( isNaN(String.fromCharCode($event.keyCode))){
   $event.preventDefault();
 }

允许浮动值!
Ramesh Ramasamy

0

我知道这是一篇过时的文章,但是对的答案的改编对来说非常有效...

angular.module("app").directive("numbersOnly", function() {
  return {
    require: "ngModel",
    restrict: "A",
    link: function(scope, element, attr, ctrl) {
        function inputValue(val) {
            if (val) {
                //transform val to a string so replace works
                var myVal = val.toString();

                //replace any non numeric characters with nothing
                var digits = myVal.replace(/\D/g, "");

                //if anything needs replacing - do it!
                if (digits !== myVal) {
                    ctrl.$setViewValue(digits);
                    ctrl.$render();
                }
                return parseFloat(digits);
            }
            return undefined;
        }
        ctrl.$parsers.push(inputValue);
    }
  };
});

0

我在

.js

$scope.numberOnly="(^[0-9]+$)";

.html

<input type="text" name="rollNo" ng-model="stud.rollNo" ng-pattern="numberOnly" ng-maxlength="10" maxlength="10" md-maxlength="10" ng-required="true" >

0

该答案是对Leopoldo答案的简化和优化

在每次按下按键时从您的输入触发功能,如下所示:

<input type="text" ng-keydown="onlyNumbers($event);"/>

您可以在控制器中以这种方式描述功能

$scope.onlyNumbers = function(event){    
    // 'up': 38,'right':39,'down':40,'left':37,
    // 'escape':27,'backspace':8,'tab':9,'enter':13,'del':46,
    // '0':48,'1':49,'2':50,'3':51,'4':52,'5':53,'6':54,'7':55,'8':56,'9':57
    var keys = { 38:true,39:true,40:true,37:true,27:true,8:true,9:true,13:true,
                 46:true,48:true,49:true, 50:true,51:true,52:true,53:true,
                 54:true,55:true,56:true,57:true };

    // if the pressed key is not listed, do not perform any action
    if(!keys[event.keyCode]) { event.preventDefault(); }
}

如果您使用的是Angular 2+,则可以通过以下方式调用此相同的函数:

<input type="text" (keydown)="onlyNumbers($event);"/>

您的Angular 2+函数应如下所示:

onlyNumbers(event) { // the logic here }

-1

用于ng-only-number仅允许数字,例如:

<input type="text" ng-only-number data-max-length=5>

-2
 <input
    onkeypress="return (event.charCode >= 48 && event.charCode <= 57) ||                         
    event.charCode == 0 || event.charCode == 46">

1
很好,您可以回答,尽管这段代码可以回答问题,但是提供了有关此代码为何和/或如何回答问题的其他上下文,从而提高了其长期价值。
Fraser

谢谢@Fraser。如果您不介意,可以请您帮我吗:)
rakib 18-3-20
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.