如何在 angular.js 中正确进行 ng-minlength、ng-maxlength 验证?

How can I do ng-minlength, ng-maxlength validations correctly in angular.js?

提问人: 提问时间:6/11/2021 最后编辑:Kinglish 更新时间:6/14/2021 访问量:332

问:

在项目中,, , 部件工作,但 , 和 部件不起作用,requiredmax-size-numbermin-size-numberpatternminlengthmaxlength

我该如何纠正此问题?

这是相关的代码部分;

<div ng-switch-when="TextBox">
  <label class="item item-input item-stacked-label">
         <span ng-if="haveHeader" class="input-label">{{header}}</span>
         <input  type="text"  style="width:100%"
                 event="component.events" 
                 validation="component"
                 ng-blur="isInAdminFormPage && checkTextTypeNumberValidation(component.shortName)"
                 name="name{{component.shortName}}" 
                 metadata="component.options" ng-disabled="isFormViewed"  string-to-date="component.options" ng-required="requiredValidation[component.shortName]"
                 ng-model="formData[component.shortName]" string-to-number="component.options" >
    </label>
  <br>

  <div ng-if="componentValidationType[component.shortName] == validationType.VALIDATION">
    <div style="color: red" ng-messages="getFormValidations(form.shortName)['name'+component.shortName].$error" ng-show="isInAdminFormPage && formInf.mainForm.$submitted">
      <div ng-message="required">{{message["required"]}}</div>
      <div ng-message="minlength">{{message["minlength"]}}</div>
      <div ng-message="maxlength">{{message["maxlength"]}}</div>
      <div ng-message="ng-pattern">{{message["ng-pattern"]}}</div>
    </div>
    <div ng-if="isInAdminFormPage" style="color: red" ng-show="showValidationMessageOfTextBox(component.shortName)  && formInf.mainForm.$submitted">
      <div ng-show="!maxNumberValidation[component.shortName].validation">{{message["max-number-size"]}}</div>
      <div ng-show="!minNumberValidation[component.shortName].validation">{{message["min-number-size"]}}</div>

    </div>
  </div>

使用这些验证的位置的图片:enter image description here

AngularJS 验证

评论

1赞 Kinglish 6/12/2021
您能否还显示一个包含这些验证属性的输入示例?
0赞 6/14/2021
那张照片对我刚刚添加的问题有帮助吗?
0赞 6/14/2021
那里有一个文本框,无论我为验证编写什么,它都应该给我该消息,必需的,min-number-size,max-number-size工作,但是ng-pattern,ng-minlength,ng-maxlength不起作用
1赞 Kinglish 6/14/2021
实际上,代码中没有 textbox 元素。也许我误解了您要做的事情,但是要应用ng-validations,我们需要一个表单输入元素来运行它们
1赞 Kinglish 6/14/2021
请将所有代码放入您的问题中,以创建该屏幕截图。就像<form>标签中的所有内容一样。有一个您要验证的表单元素,我们需要查看它的代码。您显示的代码只是错误消息 html,而不是 form 元素。

答:

1赞 Kinglish 6/14/2021 #1

复制你的例子是很困难的,但我认为这将为你提供整合所需的所有信息,以及如何监听他们的验证者。ng-patternng-minlengthng-maxlength

'use strict';

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

app.controller('MainCtrl', ['$scope', function($scope) {
  $scope.theInput = '';
  $scope.minlength = 5;
  $scope.maxlength = 10;
  $scope.thePattern = /^[a-zA-Z\s]*$/; ///^[a-zA-Z]\w{3,14}$/;

  $scope.theNumberInput = '';
  $scope.theNumberPattern = /^((?!5)[0-9]){1,3}$/; ///^[a-zA-Z]\w{3,14}$/;


}]);
.error {
  margin: 10px 0;
  padding: 5px;
  background-color: #eee;
  color: #f00;
  border: 1px solid #ccc;
}

input.ng-dirty.ng-invalid {
  background-color: #f65b90;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.9/angular.min.js"></script>
<div id="mainContainer" ng-app="app" ng-controller="MainCtrl">
  <ng-form role="form" name="theForm" novalidate>
    <p>
      Enter a word between 5 and 10 characters long - no numbers, no periods
    </p>
    <input type="text" ng-required="true" name="theInput" ng-model="theInput" ng-maxlength="{{maxlength}}" ng-minlength="{{minlength}}" ng-pattern='thePattern' />
    <div class='feedback' ng-if='theForm.$dirty'>
      <div ng-show="!theForm.theInput.$valid" class="error">
        Not valid
      </div>
      <div ng-show="theForm.theInput.$error.pattern" class="error">
        Input pattern is not valid.
      </div>
      <div ng-show="theForm.theInput.$error.minlength" class="error">
        Input length is less than the min length ({{minlength}}) </div>
      <div ng-show="theForm.theInput.$error.maxlength" class="error">
        Input length is greater than the max length ({{maxlength}})
      </div>
    </div>
    <p>
      Enter a number between 1 and 999 with no 5's in it
    </p>
    <input type="number" ng-required="true" name="theNumberInput" ng-model="theNumberInput" ng-pattern='theNumberPattern' />
    <div class='feedback'>
      <div ng-show="theForm.theNumberInput.$error.pattern" class="error">
        Input pattern is not valid.
      </div>

    </div>
  </ng-form>
</div>

评论

0赞 6/14/2021
非常感谢您抽出宝贵时间回答。我将尝试理解您的代码:)
1赞 Kinglish 6/14/2021
AngularJS 看起来很奇怪,但一旦你深入研究,它实际上非常简单(大部分)。您可能知道,Angular 2+ 完全是另一回事。参加 udemy 课程,您将快速上手
0赞 6/15/2021
您好先生,您能在空闲时间看看我的问题吗?stackoverflow.com/questions/67980687/......