vue3项目el-table表格行内编辑加输入框校验
核心点
1. el-form的model属性需要跟el-form-item的prop要对应
2. el-form的model属性绑定tableData
3. el-form-item的prop绑定字符串:scope.index+.列名(注意有个点)
4. el-form-item需要单独设置rules属性
代码示例
<el-form :model="tableData" :rules="tbRules">
<el-table :data="tableData">
<el-table-column>
<template #default="scope">
<el-form-item label="名称" :prop="scope.$index + '.name'" :rules="tbRules.name">
<!-- 封装一个输入框组件InputCell,根据当前行是否开启编辑状态(这个变量可以存在scope.row里)分别显示输入框或者展示数据 待完善 -->
<InputCell :rowData="scope.row" :column="scope.column"></InputCell>
</el-form-item>
</template>
</el-table-column>
</el-table>
</el-form>
const tableData = ref([{name: 'test'}]);
const tbRules = {
name: [
{ required: true, message: '输入不能为空', trigger: 'blur' }
]
}
遇到的问题
说明下因为我二次封装了el-table,数据和列都是传进去的,组件里通过循环输出列,所以可能才会出现这个问题吧。
提交时输入框失焦校验都通过,但是表单整体校验没过 ,给校验方法打断点执行发现 ,遇到scope.$index为-1的时候也在表单中产生了列,但这行数据实际不存在,所以校验没通过。
暂时规避办法:scope.$index等于-1时不渲染el-table-column,加个v-if判断。