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判断。

相关推荐
南_山无梅落11 天前
从传统Web到API驱动:使用Django REST Framework重构智能合同审查系统
重构·django·vue·drf
PD我是你的真爱粉12 天前
API 请求封装(Axios + 拦截器 + 错误处理)
前端框架·vue
biyezuopinvip14 天前
基于Spring Boot的投资理财系统设计与实现(毕业论文)
java·spring boot·vue·毕业设计·论文·毕业论文·投资理财系统设计与实现
biyezuopinvip14 天前
基于Spring Boot的投资理财系统设计与实现(任务书)
java·spring boot·vue·毕业设计·论文·任务书·投资理财系统设计与实现
huohuopro14 天前
Vue3 Webview 转 Android 虚拟导航栏遮挡问题记录
android·vue
码界筑梦坊15 天前
332-基于XGBoost与SHAP的可穿戴设备亚健康风险识别系统
python·数据分析·flask·vue·毕业设计
上单带刀不带妹15 天前
【Axios 实战】网络图片地址转 File 对象,附跨域解决方案
开发语言·前端·javascript·vue
SuperEugene15 天前
前端模块化与 import/export入门:从「乱成一团」到「清晰可维护」
前端·javascript·面试·vue
~央千澈~17 天前
优雅草正版授权系统 - 优雅草科技开源2月20日正式发布
python·vue·php·授权验证系统
Roc.Chang17 天前
Vite 启动报错:listen EACCES: permission denied 0.0.0.0:80 解决方案
linux·前端·vue·vite