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 小时前
Vue3 学习教程,从入门到精通,Axios 在 Vue 3 中的使用指南(37)
前端·javascript·vue.js·学习·typescript·vue·vue3
码码哈哈爱分享1 天前
Tauri 框架介绍
css·rust·vue·html
i紸定i2 天前
解决html-to-image在 ios 上dom里面的图片不显示出来
前端·ios·vue·html·html-to-image
尚学教辅学习资料3 天前
Vue3从入门到精通: 4.5 数据持久化与同步策略深度解析
vue·数据持久化
IT毕设实战小研4 天前
Java毕业设计选题推荐 |基于SpringBoot的健身爱好线上互动与打卡社交平台系统 互动打卡小程序系统
java·开发语言·vue.js·spring boot·vue·毕业设计·课程设计
第七种黄昏4 天前
大事件项目拆解:登录访问拦截实现详解
前端框架·vue·js
har01d5 天前
在 uniapp 里使用 unocss,vue3 + vite 项目
前端·uni-app·vue·uniapp·unocss
har01d7 天前
【CSS3】录音中。。。
前端·css·vue.js·vue·vue3·css3
柯北(jvxiao)7 天前
Vue vs React 多维度剖析: 哪一个更适合大型项目?
前端·vue·react
晓13138 天前
Vue2篇——第二章 Vue从指令修饰符到侦听器的全面解析(重点)
前端·javascript·vue