В примере формы мастера Vue Я попытался добавить проверку формы с Джои. Как мне настроить это логически? Цель состоит в том, чтобы контролировать поля перед переходом на вторую и последнюю страницу с помощью метода next(). Из-за простоты этой формы мастера я не хочу переходить на VueFormWizard. Для увеличения кода я стер много полей и т.д ..
next()
<template> <div> <div v-if="errorMessage" class="alert alert-danger" role="alert"> {{errorMessage}} </div> <form> <div v-if="step ===1 "> <div class="form-group"> <label for="title">Title</label> <input v-model="example.title" type="text" class="form-control" id="title" /> </div> <button @click.prevent="next()">Next step</button> </div> <div v-if="step === 2"> <div class="form-group"> <label for="userName">Email.</label> <input v-model="example.userName" type="email" class="form-control" id="userName" /> </div> <button @click.prevent="prev()">Go back</button> <button @click.prevent="createExample" type="submit" class="btn btn-primary">Submit</button> </div> </form> </div> </template> <script> import Joi from 'joi' const schema = Joi.object().keys({ title: Joi.string().alphanum().min(2).max(40).required(), userName: Joi.string().email(), }) export default { data: () => ({ step: 1, errorMessage: false, example: { title: '', userName: '' } }), watch: { example: { handler () { this.errorMessage = '' }, deep: true } }, methods: { prev () { this.step-- }, next () { this.step++ if (this.validUser()) { return false } }, createExample () { // Post request }, validUser () { const result = Joi.validate(this.huismap, schema) return true if (result.error.message.includes('title')) { this.errorMessage = 'Vul een titel in van min 2 karakters' return false } } } </script>
Вы можете использовать проверку браузера, если настроите ее следующим образом:
<form @submit.prevent="submitMyForm"> <input v-model="form.title" required minlength="4" maxlength="20" /> <button type="submit">Submit</button> </form>
Теперь ваш браузер будет препятствовать отправке формы, если title пусто, если длина меньше4 или больше 20.
title
Это решение может сделать много вещей, даже проверку регулярных выражений:
https://developer.mozilla.org/en-US/docs/Learn/HTML/Forms/Form_validation#Validating_against_a_regular_expression
Однако это ограничено небольшим набором провероки не поддерживается старыми браузерами.Если вам нужна очень специфическая проверка, вам придется использовать собственное решение, которое описано здесь https://vuejs.org/v2/cookbook/form-validation.html.