微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Vee验证-[Vue警告]:无法解析指令:validate

如何解决Vee验证-[Vue警告]:无法解析指令:validate

我想验证文本字段,尝试下面的代码

 <input v-validate="result.val=='required' ? 'required' : ''" v-model="required" :name="f_name" type="text"/>

但出现此错误

app.js:48089 [Vue警告]:无法解析指令:验证

尝试一下:

<ValidationProvider name="phone" :rules="required" v-slot="{ errors }">
  <input class="form-control" :name="phone" type="text" v-model="form.phone"/>
  </ValidationProvider>

解决方法

根据migration guide,此指令在v3.x中已删除:

具有v-validate指令的字段现在需要由ValidationProvider组件包装,并且它们需要使用v-model正确地标记自己以进行vee验证。 所以这个:

<input type="text" name="field" v-validate="'required'">
<span>{{ errors.first('field') }}</span>

将被这样重写:

<ValidationProvider name="field" rules="required" v-slot="{ errors }">
  <input type="text" v-model="value">
  <span>{{ errors[0] }}</span>
</ValidationProvider>

您的代码应类似于:

<ValidationProvider name="f_name" :rules="result.val=='Required' ? 'required' : ''" v-slot="{ errors }">
<input v-model="required" :name="f_name" type="text"/>
</ValidationProvider>

您应该将其添加到main.js中:

import { ValidationProvider } from 'vee-validate';

Vue.component('ValidationProvider',ValidationProvider);

如果您没有使用捆绑软件,而是在浏览器或CDN中使用vee-validate:

<script>
  // ...
  Vue.component('validation-provider',VeeValidate.ValidationProvider);
  // ...
</script>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。