如何在带有角度JS的输入框中仅允许字母

how to allow only alphabets in input box with angular js

本文关键字:输入 许字母 JS      更新时间:2023-09-26

我有一个带有角度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>

上面的代码正在验证文本框并在我输入数字时抛出错误。但是我需要的是,它应该限制输入数字。用户根本不应该能够在文本框中输入数字。谁能帮我做到这一点..

这是你正在寻找的ng-pattern-restrict。在您的情况下,应如下所示:

<input type="text" pattern="[a-zA-Z]+" ng-pattern-restrict />
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);
    }
  }; 
});

这将不允许数字输入。