[Vuejs]-Vuetify vform validation result in watch is delayed

0👍

At the moment your watch method is executed, the value of formValid is being displayed by the console at that precise moment, when the rule included as a computed property has not yet been executed (or anything else). Therefore at that moment the value of formValid is the one prior to the execution of nameRules and that is why with the writing of the first character it is false and with the writing of the tenth character it is still true. If what you want is to fire an event from the validation of the form, you can create another watch on the formValid data property.

0👍

Check this codesandbox I made: https://codesandbox.io/s/stack-70093759-d82kf?file=/src/components/TestForm.vue

I was able to replicate the issue in the watcher, yeah, I looks like on the first letter returns false, I guess it could be something about the life cycle of vue. Instead of using a watcher you can call a method using the @keyup event of the v-text-field

      <v-text-field
      v-model="input"      
      :rules="nameRules"               
      counter="10"
      required
      @keyup="logThis"
      ></v-text-field>

The way you’re trying to configure the validation rule as a computed property looks a bit weird for me. I usually define them in the data block like this.

   data: () => ({
     formValid: true,
     input: '',
     nameRules: [
         (v) => !!v || 'Name is required',
         (v) => (v && v.length <= 10) || 'Name must be less than 10 characters'
      ]
   }),
    methods: {
      submitForm() {
         if (this.$refs.testForm.validate()) {
            // Do something ...
         }
      },
      logThis() {         
         console.log(this.formValid)
      }
   },

You can also set the formValid as true and use the lazy-validation prop of the v-form. I also added a submit button to trigger the validate() method of the form.

Example

Leave a comment