Elementui为表格内的每一行Input框添加表单验证

需求:为表格内的每一行input输入框添加表单验证(每行有多个input框

效果:

在这里插入图片描述

html部分:

<el-form :model="forms" ref="forms" :rules="rules">
  <el-table ref="multipleTable" 
    :data="forms.tableData" 
    :height="tableHeight"
    stripe 
    style="width: 100%"
    :header-cell-style="thStyle"
    :cell-style="tdStyle">
    <el-table-column prop="ropeSkippingScore" label="跳绳成绩" min-width="115">
      <template slot-scope="scope">
        <el-form-item :prop="'tableData.'+scope.$index+'.ropeSkippingScore'" :rules="rules.ropeSkippingScore" v-if="scope.row.updated">
          <el-input v-model="scope.row.ropeSkippingScore" size="mini" placeholder="跳绳成绩"/>
        </el-form-item>
        <span v-if="!scope.row.updated">{{scope.row.ropeSkippingScore||'-'}}</span>
      </template>
    </el-table-column>
    <el-table-column prop="ropeSkippingFraction" label="跳绳分数" min-width="115">
      <template slot-scope="scope">
        <el-form-item :prop="'tableData.'+scope.$index+'.ropeSkippingFraction'" :rules="rules.ropeSkippingFraction" v-if="scope.row.updated">
          <el-input v-model="scope.row.ropeSkippingFraction" align='center' size="mini" maxlength="5" placeholder="跳绳分数" @input="changeAllScore(scope.row)"/>
        </el-form-item>
        <span v-if="!scope.row.updated">{{scope.row.ropeSkippingFraction||'-'}}</span>
      </template>
    </el-table-column>
    <el-table-column prop="chuckBallScore" label="实心球成绩" min-width="115">
      <template slot-scope="scope">
        <el-form-item :prop="'tableData.'+scope.$index+'.chuckBallScore'" :rules="rules.chuckBallScore" v-if="scope.row.updated">
          <el-input v-model="scope.row.chuckBallScore" size="mini" placeholder="实心球成绩"/>
        </el-form-item>
        <span v-if="!scope.row.updated">{{scope.row.chuckBallScore||'-'}}</span>
      </template>
    </el-table-column>
    <el-table-column prop="chuckBallFraction" label="实心球分数" min-width="115">
      <template slot-scope="scope">
        <el-form-item :prop="'tableData.'+scope.$index+'.chuckBallFraction'" :rules="rules.chuckBallFraction" v-if="scope.row.updated">
          <el-input v-model="scope.row.chuckBallFraction" size="mini" maxlength="5" placeholder="实心球分数" @input="changeAllScore(scope.row)"/>
        </el-form-item>
          <span v-if="!scope.row.updated">{{scope.row.chuckBallFraction||'-'}}</span>
      </template>
    </el-table-column>
    <el-table-column prop="langRunScore" label="长跑成绩" min-width="115">
      <template slot-scope="scope">
        <el-form-item :prop="'tableData.'+scope.$index+'.langRunScore'" :rules="rules.langRunScore" v-if="scope.row.updated">
          <el-input v-model="scope.row.langRunScore" size="mini" placeholder="长跑成绩"/>
        </el-form-item>
        <span v-if="!scope.row.updated">{{scope.row.langRunScore||'-'}}</span>
      </template>
    </el-table-column>
    <el-table-column prop="langRunFraction" label="长跑分数" min-width="115">
      <template slot-scope="scope">
        <el-form-item :prop="'tableData.'+scope.$index+'.langRunFraction'" :rules="rules.langRunFraction" v-if="scope.row.updated">
          <el-input v-model="scope.row.langRunFraction" size="mini" maxlength="5" placeholder="长跑分数" @input="changeAllScore(scope.row)"/>
        </el-form-item>
        <span v-if="!scope.row.updated">{{scope.row.langRunFraction||'-'}}</span>
      </template>
    </el-table-column>
    <el-table-column label="操作" min-width="90" >
      <template slot-scope="scope">
        <el-button size="mini" @click="updated(scope)">{{scope.row.updated==true?'保存':'修改'}}</el-button>
      </template>
    </el-table-column>
  </el-table>
 </el-form>

data部分:

forms:{
 tableData: []   
	},
rules:{  //$rules是我自己封装的,这里rules可以按照elementui规则自己填写
  ropeSkippingScore:this.$rules.focusGrade, 
  ropeSkippingFraction:this.$rules.focusScore,
  chuckBallScore:this.$rules.focusGrade,
  chuckBallFraction:this.$rules.focusScore,
  langRunScore:this.$rules.focusGrade,
  langRunFraction:this.$rules.focusScore,
},

注意:
1.这里的el-form要在el-table的外面,且data中el-table的绑定数据tableData是forms对象里的
2.rules和prop要一一对应,比如 :prop="‘tableData.’+scope.$index+’.langRunScore’" 和:rules="rules.langRunScore"里的langRunScore是一致的

现在表格里就为每个input添加了表单验证,但是由于表格里添加了表单元素,原来的布局就会混乱,表格内的input框和同行内容不再对齐。我这里是通过el-table里的:cell-style="tdStyle"来调整含有input框的列的样式
代码:

tdStyle(val){
let col = val.columnIndex==7||val.columnIndex==8||val.columnIndex==9||val.columnIndex==10||val.columnIndex==11||val.columnIndex==12
  if(col&&val.row.updated==true){
    return "text-align:center;padding-bottom:0px;padding-top:12px"
  }
}

然后就是保存后校验所有input框
代码:

updated(scope) {   //切换保存、修改按钮
      let that = this
      let errorMessage = false  //判断验证项是否全部成功
      if (scope.row.updated) {
        let colIndex = ['tableData.'+scope.$index+'.ropeSkippingScore','tableData.'+scope.$index+'.ropeSkippingFraction',
        'tableData.'+scope.$index+'.chuckBallScore','tableData.'+scope.$index+'.chuckBallFraction',
        'tableData.'+scope.$index+'.langRunScore','tableData.'+scope.$index+'.langRunFraction']
    this.$refs['forms'].validateField(colIndex,(valid) => {
      if(valid!='') errorMessage = true  //有一个验证不成功就不在继续执行
    })
    if(!errorMessage){  //所有验证项均成功再执行后续代码
      that.changeScore(scope.row)
      this.$set(scope.row,'updated',false)
    }
  } else {
    that.$set(scope.row, 'updated', true) 
  }
},
  • 9
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
你可以使用 elementui 中的表单校验来对表格中的每行输入框进行校验。 首先,在表格中定义每行输入框时,需要使用 `el-form-item` 组件包裹每个输入框,并设置 `prop` 属性,用于在校验时区分不同的输入框。 例如: ``` <el-table> <el-table-column prop="name" label="名称"> <template slot-scope="scope"> <el-form-item prop="name"> <el-input v-model="scope.row.name"></el-input> </el-form-item> </template> </el-table-column> <el-table-column prop="age" label="年龄"> <template slot-scope="scope"> <el-form-item prop="age"> <el-input v-model="scope.row.age"></el-input> </el-form-item> </template> </el-table-column> </el-table> ``` 然后,在表单中添加 `el-form` 组件,并设置 `ref` 属性,用于在代码中获取表单对象。同时,还需要为每个输入框设置校验规则,并在表单校验时调用校验方法。 例如: ``` <el-form ref="form" :model="formData" :rules="formRules"> <el-table> ... </el-table> </el-form> ``` ``` data() { return { formData: [ { name: '张三', age: 18 }, { name: '李四', age: 20 } ], formRules: { name: [ { required: true, message: '请输入名称', trigger: 'blur' } ], age: [ { required: true, message: '请输入年龄', trigger: 'blur' }, { type: 'number', message: '年龄必须为数字', trigger: 'blur' } ] } } }, methods: { validateForm() { this.$refs.form.validate(valid => { if (valid) { // 校验通过,提交表单 } else { // 校验失败,提示错误信息 } }) } } ``` 在上面的代码中,`formData` 数组中包含了表格中每行的数据,`formRules` 对象中定义了每个输入框的校验规则。在 `validateForm` 方法中,调用了表单的校验方法 `validate`,并在回调函数中根据校验结果进行处理。 需要注意的是,由于表格中的每行输入框是动态生成的,因此需要在每次表格数据发生变化时重新设置校验规则,可以在 `watch` 中监听数据变化,然后调用 `resetFields` 方法重置表单,再设置新的校验规则。 例如: ``` watch: { formData: { deep: true, handler() { this.$nextTick(() => { this.$refs.form.resetFields() this.$refs.form.clearValidate() this.setRules() }) } } }, methods: { setRules() { const rules = {} this.formData.forEach((item, index) => { rules[`name.${index}`] = [ { required: true, message: '请输入名称', trigger: 'blur' } ] rules[`age.${index}`] = [ { required: true, message: '请输入年龄', trigger: 'blur' }, { type: 'number', message: '年龄必须为数字', trigger: 'blur' } ] }) this.formRules = rules } } ``` 在上面的代码中,`setRules` 方法根据表格数据动态生成校验规则,然后通过 `this.formRules = rules` 将校验规则设置到表单中。在 `watch` 中监听 `formData` 变化时,调用 `this.setRules()` 方法重新设置校验规则。同时,调用 `this.$refs.form.resetFields()` 方法重置表单,以清除之前的校验状态。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值