vue3+elementPlus table里添加输入框并提交校验

html 复制代码
<template>
  <div style="display: flex; align-items: center">
    <h3 style="margin-right: 20px">成员信息</h3>
  </div>

  <el-form :model="info" ref="forms">
    <el-table
      :data="info.membersList"
      @selection-change="handleSelectionChange"
    >
      <el-table-column type="selection" width="55" />
      <el-table-column type="index" label="序号" width="55" />
      <el-table-column label="成员号码" prop="userNumber">
        <template #default="row">
          <el-form-item
            :prop="'membersList.' + row.$index + '.userNumber'"
            :rules="formRules.userNumber"
          >
            <el-input
              placeholder="请输入成员号码"
              v-model="info.membersList[row.$index].userNumber"
            />
          </el-form-item>
        </template>
      </el-table-column>
      <el-table-column label="机顶盒侧mac" prop="age">
        <template #default="row">
          <el-form-item
            :prop="'membersList.' + row.$index + '.macCode'"
            :rules="formRules.macCode"
          >
            <el-input
              placeholder="请输入机顶盒侧mac"
              v-model="info.membersList[row.$index].macCode"
            />
          </el-form-item>
        </template>
      </el-table-column>
      <el-table-column label="机顶盒stbid" prop="snCode">
        <template #default="row">
          <el-form-item
            :prop="'membersList.' + row.$index + '.snCode'"
            :rules="formRules.snCode"
          >
            <el-input
              placeholder="请输入机顶盒stbid"
              v-model="info.membersList[row.$index].snCode"
            />
          </el-form-item>
        </template>
      </el-table-column>
      <el-table-column label="电视账号" prop="tvAccount">
        <template #default="row">
          <el-form-item
            :prop="'membersList.' + row.$index + '.tvAccount'"
            :rules="formRules.tvAccount"
          >
            <el-input
              placeholder="请输入电视账号"
              v-model="info.membersList[row.$index].tvAccount"
            />
          </el-form-item>
        </template>
      </el-table-column>
      <el-table-column label="备注(如房间号)" prop="remark">
        <template #default="row">
          <el-form-item
            :prop="'membersList.' + row.$index + '.remark'"
            :rules="formRules.remark"
          >
            <el-input
              placeholder="请输入备注(如房间号)"
              v-model="info.membersList[row.$index].remark"
            />
          </el-form-item>
        </template>
      </el-table-column>
      <el-table-column label="操作">
        <template #default="row">
          <el-form-item :prop="'membersList.' + row.$index + '.oprcode'">
            <el-select
              placeholder="请选择操作类型"
              style="margin-right: 10px"
              v-model="info.membersList[row.$index].oprcode"
            >
              <el-option label="添加" value="01" />
              <el-option label="删除" value="02" />
            </el-select>
          </el-form-item>
        </template>
      </el-table-column>
    </el-table>
  </el-form>
</template>
TypeScript 复制代码
<script setup name="index" lang="ts">
  import {
    Search,
    Plus,
    Upload,
    Minus,
    Download,
  } from '@element-plus/icons-vue'
  import type { FormInstance } from 'element-plus'
  const { proxy } = getCurrentInstance()
  let info: any = reactive({
    membersList: [],
  })
  const formRules = reactive({
    userNumber: [
      { required: true, message: '请输入成员号码', trigger: 'blur' },
    ],
    macCode: [
      { required: true, message: '请输入机顶盒侧mac', trigger: 'blur' },
    ],
    snCode: [{ required: true, message: '请输入机顶盒stbid', trigger: 'blur' }],
  })
  const forms = ref<FormInstance>()
  const save = async () => {
    if (!forms) return
    await forms.value?.validate((valid: any) => {
      if (valid) {
      }
    })
  }
</script>
相关推荐
苹果酱05671 小时前
「Mysql优化大师一」mysql服务性能剖析工具
java·vue.js·spring boot·mysql·课程设计
真的很上进4 小时前
如何借助 Babel+TS+ESLint 构建现代 JS 工程环境?
java·前端·javascript·css·react.js·vue·html
web130933203984 小时前
vue elementUI form组件动态添加el-form-item并且动态添加rules必填项校验方法
前端·vue.js·elementui
supermapsupport6 小时前
iClient3D for Cesium在Vue中快速实现场景卷帘
前端·vue.js·3d·cesium·supermap
m0_748254886 小时前
vue+elementui实现下拉表格多选+搜索+分页+回显+全选2.0
前端·vue.js·elementui
噢,我明白了8 小时前
同源策略:为什么XMLHttpRequest不能跨域请求资源?
javascript·跨域
sanguine__8 小时前
APIs-day2
javascript·css·css3
苹果醋38 小时前
Golang的文件加密工具
运维·vue.js·spring boot·nginx·课程设计
关你西红柿子8 小时前
小程序app封装公用顶部筛选区uv-drop-down
前端·javascript·vue.js·小程序·uv
济南小草根8 小时前
把一个Vue项目的页面打包后再另一个项目中使用
前端·javascript·vue.js