Angular js Ng-pattern不允许更新模型

时间:2017-10-16 16:54:37

标签: angularjs ng-pattern angularjs-ng-pattern

我必须验证文本框,当用户输入4位数作为9999时显示错误消息。因此我使用ng-pattern方法显示错误消息但ng-pattern不允许更新对象。我的代码如下:

  <md-input-container class="" style="margin:5px 0px; margin-right:15px;">

      <input type="password" name="numCode" ng-model="datas.part[1].Value" ng-value="datas.part[1].Value" maxlength="4" ng-pattern="/(?!9{4})\d{4}/" ng-keydown="vm.testCode(datas.part[1].Value)" class="ng-pristine ng-valid md-input ng-touched"  aria-invalid="false" style="" autocomplete="off" required>
      <div ng-messages="vm.formName.numCode.$error" class="allign-padding-bottom" role="alert">
           <div ng-message-exp="['minlength','maxlength','pattern']">
                        {{::'testcode'|translate}}
            </div>
       </div>
    </md-input-container>

 vm.testCode= function (val) {
            console.info("sdf",val);
            vm.showConfirmUserCode = true;
            ///vm.isDeviceEnabled = false;
        }

在ng-keydown方法中,模型没有更新。它在vm.formName.numCode中显示未定义。$ viewvalue.kindly帮我解决这个问题&amp;检查我的ng-pattern。如果删除我的ng-pattern意味着我有更新的模型

1 个答案:

答案 0 :(得分:0)

请检查这个plunker: http://plnkr.co/edit/g0wsbFnfi6TEW76orxIJ?p=preview

 <body ng-controller="MainCtrl">
    <p>Hello {{name}}!</p>

    <form name="form1" novalidate>

  <input type="password" name="numCode" ng-model="inputText" ng-value="inputText" ng-pattern="/(?!9{4})\d{4}/" ng-maxlength="4" ng-keydown="testCode(inputText)" aria-invalid="false" style="" autocomplete="off" required>
  <div ng-messages="form1.numCode.$error" role="alert">
           <div ng-message="pattern">pattern error</div>
            <div ng-message="maxlength">maxlength error</div>
             <div ng-message="required">required error</div>
   </div>
</form>
  </body>

您是否将角度消息引用为单独的库?如果ng-keydown是有效文本并且错误消息正确显示,那么ng-keydown就可以正常工作。