0

ng-model问题:如果我无法命名表单及其元素,如何仅使用 显示验证错误。

我有一个 html 表单来收集信用卡详细信息。为了防止信用卡数据接触到我的服务器,我无法命名表单元素。所以我的表格看起来像:

<form ng-submit="vm.processForm()">

  <div class="form-row">
    <label>
      <span>Card Number</span>
      <input type="text" size="20" data-stripe="number" ng-model="vm.number" required>
    </label>
  </div>

  <div class="form-row">
    <label>
      <span>Expiration (MM/YY)</span>
      <input type="text" size="2" data-stripe="exp_month" ng-model="vm.exp_month" required>
    </label>
    <span> / </span>
    <input type="text" size="2" data-stripe="exp_year" ng-model="vm.exp_year" required>
  </div>

  <div class="form-row">
    <label>
      <span>CVC</span>
      <input type="text" size="4" data-stripe="cvc" ng-model="vm.cvc" required>
    </label>
  </div>

  <input type="submit" class="submit" value="Submit Payment">
</form>

通常在 Angular 中,我曾经使用表单元素名称检查验证,例如:

<p ng-show="userForm.creditcard.$error.required">Your credit card number is required.</p>

但是由于我无法命名表单及其元素,如何仅使用 ng-model 来显示验证错误?因为,以下不起作用:

<p ng-show="vm.number.$error.required">Your credit card number is required.</p>

我正在使用 Angular v1.4.8。

4

1 回答 1

2

我创建了一个指令来导出模型控制器。我认为这不是最好的方法,但它确实有效。

.directive('exportModel', function () {
    return {
    restrict: 'A',
    require: 'ngModel',
    link: function (scope, element, attr, ngModel) {
        attr.$observe('exportModel', function (value) {
        scope[value] = ngModel;
      })
    }
  }
})

http://jsfiddle.net/Lvc0u55v/11352/

于 2016-10-27T20:03:01.247 回答