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属性

代码示例

html 复制代码
<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>
javascript 复制代码
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判断。

相关推荐
蜚鸣20 小时前
Vue的快速入门
vue
吃饭最爱2 天前
⽹络请求Axios的概念和作用
vue
魂尾ac2 天前
Django + Vue3 前后端分离技术实现自动化测试平台从零到有系列 <第一章> 之 注册登录实现
后端·python·django·vue
是罐装可乐2 天前
深入理解 Vue3 Router:三种路由模式的工作原理与实战应用
架构·vue·路由·history·hash·ssr·router
老华带你飞3 天前
租房平台|租房管理平台小程序系统|基于java的租房系统 设计与实现(源码+数据库+文档)
java·数据库·小程序·vue·论文·毕设·租房系统管理平台
zhz52143 天前
Spring Boot + Redis 缓存性能优化实战:从5秒到毫秒级的性能提升
java·spring boot·redis·缓存·vue
小胖墩有点瘦4 天前
【基于协同过滤的校园二手交易平台】
java·vue·毕业设计·springboot·计算机毕业设计·协同过滤·校园二手交易平台
小圣贤君4 天前
小说创作中的时间轴体验设计:事序图交互与用户体验优化
electron·vue·甘特图·时序图·写作软件
知识分享小能手4 天前
React学习教程,从入门到精通,React 构造函数(Constructor)完整语法知识点与案例详解(16)
前端·javascript·学习·react.js·架构·前端框架·vue
@AfeiyuO5 天前
分类别柱状图(Vue3)
typescript·vue·echarts