Element-UI 对 v-for 生成的动态项进行验证
Element-UI validation on dynamic items generated by v-for
我想使用 element-ui 和 asyc-validator 验证 table 中的字段,但不知道我该怎么做!没有找到任何合适的文档和讨论主题,所以在这里发布我的问题。
vue 模板:
<el-form :model='myForm' :rules='rules' ref='myForm'>
<div v-for="(item, index) in items" :key="index">
<div class="col">
<el-form-item label="Description" prop="description">
<el-input v-model="item.description"></el-input>
</el-form-item>
<div>
<div class="col">
<el-form-item label="Price" prop="price">
<el-input v-model="item.price"></el-input>
</el-form-item>
<div>
</div>
</el-form>
我试过这样设置规则,但它不起作用
rules: {
"description": { required: true, message: 'is required', trigger: 'blur' },
"price": { required: true, message: 'is required', trigger: 'blur' }
}
这是 jsfiddle:https://jsfiddle.net/cgL6y9kq/15/
尝试提交表单,将出现错误,即使您已填写 requi 红色字段,该错误仍将存在。
您需要使用索引动态设置 :props 并在 el-form-item 中添加规则。在此处检查 jsfiddle:https://jsfiddle.net/cgL6y9kq/34/
<el-form-item label="Description"
:prop="'items.' + index + '.description'"
:rules="{required: true, message: 'description is required', trigger: 'blur'}">
<el-input v-model="item.description"></el-input>
</el-form-item>
我想使用 element-ui 和 asyc-validator 验证 table 中的字段,但不知道我该怎么做!没有找到任何合适的文档和讨论主题,所以在这里发布我的问题。
vue 模板:
<el-form :model='myForm' :rules='rules' ref='myForm'>
<div v-for="(item, index) in items" :key="index">
<div class="col">
<el-form-item label="Description" prop="description">
<el-input v-model="item.description"></el-input>
</el-form-item>
<div>
<div class="col">
<el-form-item label="Price" prop="price">
<el-input v-model="item.price"></el-input>
</el-form-item>
<div>
</div>
</el-form>
我试过这样设置规则,但它不起作用
rules: {
"description": { required: true, message: 'is required', trigger: 'blur' },
"price": { required: true, message: 'is required', trigger: 'blur' }
}
这是 jsfiddle:https://jsfiddle.net/cgL6y9kq/15/ 尝试提交表单,将出现错误,即使您已填写 requi 红色字段,该错误仍将存在。
您需要使用索引动态设置 :props 并在 el-form-item 中添加规则。在此处检查 jsfiddle:https://jsfiddle.net/cgL6y9kq/34/
<el-form-item label="Description"
:prop="'items.' + index + '.description'"
:rules="{required: true, message: 'description is required', trigger: 'blur'}">
<el-input v-model="item.description"></el-input>
</el-form-item>