我遵循了有关使用Vue.js进行HTML 5表单验证的不错的教程,并且尝试了很多次,在失败的输入旁边添加了消息错误,但我做不到。这是教程:https : //logaretm.com/blog/2019-05-03-html-aided-vuejs-form-validation/
这是我的代码:
function updateMessage(el, vm) {
vm.errors = Object.assign({}, vm.errors, {
[el.name]: el.validationMessage
});
}
export const ValidateMixin = {
data: () => ({
errors: {}
}),
computed: {
hasErrors() {
// Check if we have errors.
return Object.keys(this.errors).some(key => {
console.log(this.errors)
return !!this.errors[key];
});
}
},
directives: {
validate: {
bind(el, _, vnode) {
const vm = vnode.context;
el.addEventListener("input", e => {
updateMessage(e.target, vm);
});
vnode.context.$on("validate", () => {
updateMessage(el, vm);
});
}
}
},
methods: {
validate() {
this.$emit("validate");
}
}
};
我想在每个输入字段旁边的跨度中显示错误消息
mixin的errors
object属性包含元素映射name
到该元素的验证错误消息。例如,在输入中输入无效的电子邮件地址<input name="myEmail" type="email" v-validate>
将在中创建一条验证消息errors.myEmail
。
您可以errors
在模板中使用该对象将元素的错误消息绑定span
到相应对象的旁边input
:
<input name="myEmail" type="email" v-validate>
<span v-if="errors.myEmail">{{ errors.myEmail }}</span>
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句