Search code examples
javascriptvalidationpasswordsyuppassword-confirmation

Yup password confirmation validation doesn't work


I want to validate password confirmation with Yup but it doesn't work.

This is my code :

<template>
  <form @submit="onSubmit">
    <div>
      <label for="password">Password</label>
      <div>
        <input
          id="password"
          v-model.trim="password"
          name="password"
        />
      </div>
    </div>
    <div>{{ passwordErrorMessage }}</div>
    <br>
    <div>
      <label for="confirmPassword">Confirm Password</label>
      <div>
        <input
          id="confirmPassword"
          v-model.trim="confirmPassword"
          name="confirmPassword"
        />
      </div>
    </div>
    <div>{{ confirmPasswordErrorMessage }}</div>    
    <br>
    <button>Submit</button>
  </form>

</template>

<script>
import { useField, useForm } from "vee-validate";
import * as yup from "yup";

export default {
  setup() {
    const { handleSubmit } = useForm();
    const onSubmit = handleSubmit((values) => {
      alert(JSON.stringify(values, null, 2));
    });
    
    const { value: password, errorMessage: passwordErrorMessage } = useField(
      "password",
      yup
        .string()
        .required()
        .min(5)
    );

    const { value: confirmPassword, errorMessage: confirmPasswordErrorMessage } = useField(
      "confirmPassword",
      yup
        .string()
        .required()
        .oneOf([yup.ref("password")], "Passwords do not match"),
    );

    return {
      password,
      passwordErrorMessage,
      confirmPassword,
      confirmPasswordErrorMessage,
      onSubmit
    }
  }
};
</script>

This is the demo code on codesandbox

When running the code above no error appears but the password confirmation does not work.

Can anyone help just to get the password confirmation to work?


Solution

  • Apparently the only way it works is by using validationSchema in the useForm

    The final setup function will look like this:

    setup() {
        const {
            handleSubmit
        } = useForm({
            validationSchema: yup.object({
                password: yup.string().required().min(5),
                confirmPassword: yup
                    .string()
                    .required()
                    .oneOf([yup.ref("password")], "Passwords do not match"),
            }),
        });
        const onSubmit = handleSubmit((values) => {
            alert(JSON.stringify(values, null, 2));
        });
    
        const {
            value: password,
            errorMessage: passwordErrorMessage
        } = useField(
            "password"
        );
    
        const {
            value: confirmPassword,
            errorMessage: confirmPasswordErrorMessage,
        } = useField("confirmPassword");
    
        return {
            password,
            passwordErrorMessage,
            confirmPassword,
            confirmPasswordErrorMessage,
            onSubmit,
        };
    },