Как я могу использовать проверку полей в форме мастера Vue? - PullRequest
0 голосов
/ 13 марта 2019

В примере формы мастера Vue Я попытался добавить проверку формы с Джои. Как мне настроить это логически? Цель состоит в том, чтобы контролировать поля перед переходом на вторую и последнюю страницу с помощью метода next(). Из-за простоты этой формы мастера я не хочу переходить на VueFormWizard. Для увеличения кода я стер много полей и т.д ..

<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>

1 Ответ

0 голосов
/ 14 марта 2019

Вы можете использовать проверку браузера, если настроите ее следующим образом:

<form @submit.prevent="submitMyForm">
    <input v-model="form.title" required minlength="4" maxlength="20" />

    <button type="submit">Submit</button>
</form>

Теперь ваш браузер будет препятствовать отправке формы, если title пусто, если длина меньше4 или больше 20.

Это решение может сделать много вещей, даже проверку регулярных выражений:

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.

...