我有一个带有 veevalidate 的多个文本字段中继器。问题是,当第一个字段有错误时,另一个字段会受到影响。并且,在添加新字段时将继承该错误。
这是我的html
<div id="app">
<form class="ui form" @submit.prevent="onSubmit">
<div class="repeater" v-for="(field, index) in fieldsRepeater">
<div class="field" :class="{error: errors.has('fname')}">
<label>First Name</label>
<input type="text" name="fname" placeholder="First name" v-validate="'required'" v-model="fname">
<span class="error" v-if="errors.has('fname')">{{errors.first('fname')}}</span>
</div>
<div class="field" :class="{error: errors.has('lname')}">
<label>Last Name</label>
<input type="text" name="lname" placeholder="Last name" v-validate="'required'" v-model="lname">
<span class="error" v-if="errors.has('lname')">{{errors.first('lname')}}</span>
</div>
</div>
<button type="button" class="ui button" @click="AddField">Add Field</button>
<button type="submit" class="ui submit button">Submit</button>
</form>
</div>
这是我的 vuejs
Vue.use(VeeValidate)
new Vue({
el: '#app',
data() {
return {
fieldsRepeater: [{
fname: '',
lname: '',
}],
}
},
methods: {
AddField() {
this.fieldsRepeater.push({
fname: '',
lname: '',
});
},
onSubmit() {
this.$validator.validateAll()
if (!this.errors.any()) {
alert('submit')
}
}
}
})
这是我的 jsfiddle -> https://jsfiddle.net/m67d8f4x/66/
我们如何对每组字段应用不同的验证?
我该如何解决这个问题?