我正在使用Vuetify和VueJS(最新版本)。
以下是 Login.vue 的小模板:
<template>
<v-layout align-center justify-center>
<v-flex xs12 sm8 md4>
<v-card class="elevation-12">
<v-toolbar dark color="success">
<v-toolbar-title>Login form</v-toolbar-title>
<v-spacer></v-spacer>
</v-toolbar>
<v-card-text>
<v-form @submit.prevent="checkLogin">
<v-text-field prepend-icon="person" id="userLogin" v-model="userLogin" placeholder="my@login.com"></v-text-field>
<v-text-field prepend-icon="lock" id="userPassword" v-model="userPassword" placeholder="password" type="password"></v-text-field>
</v-form>
</v-card-text>
<v-card-actions>
<v-spacer></v-spacer>
<!-- TODO fix the bug when form.submit not works -->
<v-btn type="submit" color="success">Login</v-btn>
</v-card-actions>
</v-card>
</v-flex>
</v-layout>
</template>
因此,如果您看到, v-form 上有一个带有 checkLogin 的 @ submit.prevent ,它就无法正常工作在输入时单击提交按钮或按下输入按钮。使用 @submit 而不使用阻止也无效。
但是!如果我将事件处理程序放在 v-btn 上,如下所示:
<v-btn @click.native="checkLogin">
单击按钮后(不输入输入字段中的输入)全部按预期工作。
那么,请告诉我, v-form 子事件处理的错误是什么? 谢谢!
答案 0 :(得分:15)
您的提交按钮不在表单内,因此不会触发提交事件。
重新构建您的标记或尝试在表单上设置id
并使用form
attribute on the button,例如
<v-form @submit.prevent="checkLogin" id="check-login-form">
和
<v-btn type="submit" color="success" form="check-login-form">Login</v-btn>