Как проверить модель в валидации нокаутом

Я создал модель представления и хочу проверить эту модель, используя валидацию. Вот мой вид модели

function SignInViewModel() {
   var self = this;

   self.userName = ko.observable('').extend({
      required: true,
      pattern: {
         message: 'Username must be a valid email address',
         params: /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/
      }
   });

   self.password = ko.observable('').extend({
      required: true,
      pattern: {
         message: 'Password must be alpha numeric and 4-8 character long .',
         params: /^(?=.*\d).{4,8}$/
     }
   });

   self.login = function () {
      // Want to call validate function here
      $.post("/account/login", { "userName": self.userName(), "password": self.password() })
         .done(function (result) {
            redirect(result.redirect);
     });
    }
}

ko.validation.configure({
   decorateElement: false,
   errorElementClass: "error",   // class name
   insertMessages: false,
   grouping: { deep: true, observable: true }
});

Я хочу проверить свою модель при вызове моей функции входа в систему.

1 ответ

Решение

Создайте группу проверки как

self.errors = ko.validation.group(self);

добавить вычисленный

self.canLogin = ko.computed(function() {
   return self.errors().length === 0;
});

По вашему мнению добавьте эту привязку данных к вашей кнопке

data-bind="click: login, enable: canLogin"
Другие вопросы по тегам