Привязка данных Knockout validatedObservable не работает должным образом

Я пытаюсь привязать данные к validatedObservable, но элемент управления не выглядит обновляемым, как другие наблюдаемые нокауты.

Поиграйте здесь, http://jsfiddle.net/EricHerlitz/x7UUg/

Краткое объяснение

// variable with the data bound observable
that.validationErrors = ko.validatedObservable();

// Elements to validate
var validationGroup = {
    email1: that.email1,
    firstName: that.firstName
};

// Trying to use the validatedObservable in a normal knockout way doesn't work
that.validationErrors(validationGroup);

// This will fill the variable with the observable result but as usual when performing this pattern the viewmodel must be rebound.
that.validationErrors = ko.validatedObservable(validationGroup);

Источник

<h3>Registrering</h3>
<div class="form-group">
    <label for="Email1">E-postadress</label>
    <input data-bind="value: email1" id="Email1" class="form-control" placeholder="E-postadress (du kommer få lösenords-länk skickad hit)" />
</div>
<div class="form-group">
    <label for="Firstname">Förnamn</label>
    <input data-bind="value: firstName" id="Firstname" class="form-control" placeholder="Förnamn" />
</div>

<button type="button" class="btn btn-primary" data-bind="click: registerClick">Registrera</button>

<div class="alert alert-danger" data-bind="visible: !validationErrors.isValid()">
    <button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>
    <h4>There be dragons!</h4>
    <div data-bind="foreach: validationErrors.errors">
        <div data-bind="text: $data"></div>
    </div>
</div>

Js

var GK = GK || {};
GK.VM = GK.VM || {};

GK.VM.Member = function (template) {
    /*** Private variables ***/
    var that = this;

    /*** Public variables ***/
    that.validationErrors = ko.validatedObservable();

    // variables with validation, https://github.com/Knockout-Contrib/Knockout-Validation
    that.email1 = ko.observable().extend({
        required: { params: true, message: "missingEmail" },
        pattern: { params: /^([\d\w-\.]+@([\d\w-]+\.)+[\w]{2,4})?$/, message: "wrongEmailFormat" }
    });
    that.firstName = ko.observable().extend({
        required: { params: true, message: "missingFirstName" }
    });

    that.registerClick = function () {

        // Elements to validate
        var validationGroup = {
            email1: that.email1,
            firstName: that.firstName
        };

        // This would be ideal but doesn't work
        //that.validationErrors(validationGroup);
        //console.log(that.validationErrors.errors()); // does not contain any erros

        // This will destroy the data-bind but register the validatedObservable
        // Requires rebinding of the control :(
        that.validationErrors = ko.validatedObservable(validationGroup);
        console.log(that.validationErrors.errors()); // contains errors
    };
};

var viewModel = new GK.VM.Member();
ko.applyBindings(viewModel);

Любые советы, как справиться с этим? Спасибо.


person Eric Herlitz    schedule 24.02.2014    source источник
comment
Почему вы хотите обновить свой validatedObservable? Вы хотите проверить разные части вашей модели на разных действиях?   -  person nemesv    schedule 24.02.2014
comment
Нет, но проверка должна срабатывать на that.registerClick.   -  person Eric Herlitz    schedule 24.02.2014
comment
В этом случае и поскольку вы все равно создаете отдельную область проверки, я бы инициализировал validationErrors в начале и создал наблюдаемую showErrorMessages и использовал ее, чтобы показать скрытие ошибок: jsfiddle.net/jJ9JS/1   -  person nemesv    schedule 24.02.2014
comment
@nemesv Подойдет, спасибо за идею. Пожалуйста, опубликуйте это как ответ, и я отмечу это!   -  person Eric Herlitz    schedule 24.02.2014


Ответы (1)


В настоящее время вы не можете обновить validatedObservable после того, как он был создан, без его полного повторного создания.

Однако, если вам не нужен этот динамический аспект добавления к нему удаляющих свойств, а вам просто нужно показать собранные сообщения проверки на основе критериев (когда вызывается registerClick), то есть альтернативные решения.

Одним из решений было бы создать validatedObservable в обычном режиме:

that.validationErrors = ko.validatedObservable({
    email1: that.email1,
    firstName: that.firstName
});

Затем добавьте новую наблюдаемую:

that.showErrorMessages = ko.observable();

и использовать это в пользовательском интерфейсе

<div class="alert alert-danger" 
    data-bind="visible: showErrorMessages() && !validationErrors.isValid()">

и в registerClick для переключения, когда должны отображаться сообщения проверки:

that.registerClick = function () {
    that.showErrorMessages(true);
};

Демонстрация JSFiddle.

person nemesv    schedule 24.02.2014