Knockout Validation evaluates immediately on load

letsgetsilly picture letsgetsilly · Dec 3, 2012 · Viewed 9k times · Source

I'm using MVC, Knockout, and Knockout Validation to validate my view model.

I'm running into an issue where the validation for view model properties are firing immediately upon loading. In other words, "This field is required" shows up next to my inputs before a user has attempted to change their values.

This problem is specifically happening with dropdown (select) controls.

I'm guessing that this is a problem that I've created by somehow unintentionally changing/accessing/mutating the observable in another part of my javascript code. However, I don't know how to track this down.

Is there a way that I can somehow subscribe or track the even that fires that causes validation in Knockout Validation? I just need to know why this is firing in the way it is. I'm pretty confident that the value of the isValid() function is consistently false.

Here's a sample of how my HTML is setup on page load, unmolested:

<select class="highlightable validationElement" name="obsstate" data-bind="value: standardAnswers.ans106_1.value" required="true">
    <option value="">-- Select -- </option>
        <option value="AK">AK</option>
        <option value="AL">AL</option>
        etc...

</select>

As displayed on my local machine

Answer

Velmurugan picture Velmurugan · Nov 6, 2013

After applying the bindings for the viewmodel. Then for that viewmodel make showAllMessages as false

Example

YourViewmodelname.errors.showAllMessages(false);