elementUI表格中添加输入框并校验 & el-form-item标签上rules写法

475 阅读1分钟

一、效果

动画.gif

二、实现

<template>
  <div>
    <el-button @click="addItem" size="small" type="primary">添加报修事项</el-button>
    <el-form :model="formData" ref="formRef" :rules="rules">
      <el-form-item label="报修地点" prop="place" label-width="100px">
        <el-input v-model="formData.place" />
      </el-form-item>
      <el-form-item label="联系方式" prop="phone" label-width="100px">
        <el-input v-model="formData.phone" />
      </el-form-item>
      <el-table :data="formData.tableData">
        <el-table-column prop="id" label="id" width="100" />
        <el-table-column label="物品名称">
          <template slot-scope="scope">
            <el-form-item :prop="'tableData.' + scope.$index + '.goodsName'" :rules="rules.goodsName">
              <el-input v-model="scope.row.goodsName" placeholder="物品名称" />
            </el-form-item>
          </template>
        </el-table-column>
      </el-table>
    </el-form>
    <el-button type="primary" @click="handleSubmit">提交</el-button>
  </div>
</template>
<script>
export default {
  data() {
    return {
      formData: {
        place: '',
        phone: '',
        tableData: [
          { id: 1, goodsName: '' },
          { id: 2, goodsName: '' },
        ],
      },
      // 表单校验
      rules: {
        place: [{ required: true, message: '报修地点不能为空', trigger: ['blur', 'change'] }],
        phone: [{ required: true, message: '联系方式不能为空', trigger: ['blur', 'change'] }],
        goodsName: [{ required: true, message: '物品名称不能为空', trigger: ['blur', 'change'] }],
      },
    }
  },
  methods: {
    addItem() {
      const item = { id: this.formData.tableData.length, goodsName: '' }
      this.formData.tableData.push(item)
    },
    handleSubmit() {
      this.$refs.formRef.validate((valid) => {
        if (!valid) return
        console.log(JSON.parse(JSON.stringify(this.formData)))
      })
    },
  },
}
</script>

表格某一列校验不通过,将该列滚动到表格左侧

效果:

动画.gif

实现:

el-table标签添加ref="tableRef"

    handleSubmit() {
      this.$refs.formRef.validate(valid => {
        if (!valid) return this.scrollToFirstError()
        console.log(JSON.parse(JSON.stringify(this.formData)))
      })
    },
    scrollToFirstError() {
      this.$nextTick(() => {
        const tableWrapper = this.$refs.tableRef.$el.querySelector('.el-table__body-wrapper')
        const errEle = this.$refs.tableRef.$el.querySelector('.is-error')
        if (errEle) {
          const tableRect = tableWrapper.getBoundingClientRect()
          const rect = errEle.getBoundingClientRect()
          const offset = rect.left - tableRect.left
          tableWrapper.scrollLeft += offset
        }
      })
    }

三、el-form-item标签上rules写法

需求:编辑时,如果password没有发生变化,则不校验;如果password发生变化,则进行密码的校验

image.png

          <el-form-item label="Password" prop="password" :rules="[{ required: true, validator: form.password !== form.passwordCopy && checkPassword, trigger: 'change' }]">
            <el-input v-model="form.password" placeholder="Please Enter" clearable />
          </el-form-item>

image.png

四、深层次嵌套表单校验prop写法

image.png

image.png

image.png