【发布时间】:2019-07-15 06:50:15
【问题描述】:
我有用户列表内联编辑表结构。每行代表一个用户。我正在编辑用户并使用 vee validate 进行验证
validateState(ref) {
if (
this.veeFields[ref] &&
(this.veeFields[ref].dirty || this.veeFields[ref].validated)
) {
return !this.veeErrors.has(ref)
}
return null
},
saveUserUpdate: function(user) {
this.$validator.validateAll().then((result) => {
debugger
if (!result) {
return
} else {
//code to save user api
}
})
}
<tr v-for="(user, userIndex) in userList" :key="userIndex">
<td>
<span v-show="user.isEditing">
<b-form-input size="sm" v-model="user.fullName" :name="'tbnewFullName' + user.unique_id" :state="validateState('tbnewFullName' + userIndex)" :aria-describedby="'tbnewFullName-feedback' + userIndex"></b-form-input>
<b-form-invalid-feedback :id="'tbnewFullName-feedback' + userIndex">
Required.
</b-form-invalid-feedback>
</span>
<div v-show="!user.isEditing">
{{user.fullName}}
</div>
</td>
</tr>
我不知道我在这里做错了什么,但在saveUserUpdate 中没有触发验证。 validateState 中的 veeFields 列表未显示我的用户名字段。 veeFields 还显示以前表单中的字段列表。
【问题讨论】:
-
saveUserUpdate在哪里被调用? -
每一行的内嵌保存按钮
标签: vuejs2 vee-validate