如何只允许带有角度js的输入框中的字母

时间:2016-03-11 10:56:43

标签: javascript html angularjs

我有一个带角度js验证的输入框..代码是

    <div class="col-sm-12">
        <input type="text" name="drug_name" class="form-control" placeholder="Drug name" ng-pattern="/[aA-zZ\s]$/" ng-model="vmp.medication.drug_name" maxlength="150" typeahead="drugn as drugn.drugName for drugn in vmp.drugList | filter:$viewValue" autocomplete="off"  required>
<span class="pull-right font-10">(Max 150 chars.)</span>
  <span ng-messages="form.drug_name.$dirty && form.drug_name.$error">
   <span ng-message="required" class="error-inner">Drug name is required.</span>
   <span ng-message="pattern" class="error-icn">Only Alphabets are allowed</span> </span>
     </div>

如果输入数字,上面的代码验证文本框并抛出错误。但我需要的是,它应该限制输入数字。用户根本不能在文本框中输入数字..任何人都可以帮助这样做..

2 个答案:

答案 0 :(得分:3)

以下是您正在寻找的内容ng-pattern-restrict。 在你的情况下应该看起来像:

<input type="text" pattern="[a-zA-Z]+" ng-pattern-restrict />

答案 1 :(得分:0)

app.directive('name', function() {
  return {
    require: 'ngModel',
    link: function (scope, element, attr, ngModelCtrl) {
      function fromUser(text) {
        var transformedInput = text.replace(/[^A-Za-z ]/g, '');
        console.log(transformedInput);
        if(transformedInput !== text) {
            ngModelCtrl.$setViewValue(transformedInput);
            ngModelCtrl.$render();
        }
        return transformedInput;
      }
      ngModelCtrl.$parsers.push(fromUser);
    }
  }; 
});

这不允许数字输入。