el-select multiple表单校验问题

记录一个el-select复选框表单校验例子

1、一打开页面就会触发校验

解决方案:设置初始值为空数组

2、选中下拉数据,不会再次触发校验,导致提示文字一直存在

解决这个问题,首先先看看v-model 、prop属性、rules校验是否正确,这里注意el-select的rules校验的trigger应该是change。

如果以上都没问题,那么还有一个原因就是:嵌套太深,导致form检测不到ruleForm的变化

解决方案:

javascript 复制代码
 // 我这里用的是
      vulTypeChange() {
        this.form = { ...this.form }
      },

3、完没解决思路

1)添加form表单:rule方式验证

html 复制代码
<el-form ref="form" :model="form" :rules="rules" label-width="80px" style="margin-bottom: 20px">
        
        <el-row>
          <el-col :span="12">
            <el-form-item label="接收人" prop="receivers">
              <el-select v-model="form.receivers" placeholder="请选择接收人" filterable multiple clearable style="width: 100%" :disabled="this.disabled"
                >
                <el-option v-for="item in users" :key="item.userName" :label="item.nickName" :value="item.userName" />
              </el-select>
            </el-form-item>
          </el-col>
          
        </el-row>

      </el-form>
javascript 复制代码
rules: {
          
          receivers: [
            { required: true, validator: picValidator, trigger: 'change' },
          ]
         
        },

注意rule中验证方式应该是"change"

2)给下拉框添加change函数

html 复制代码
<el-form ref="form" :model="form" :rules="rules" label-width="80px" style="margin-bottom: 20px">
        
        <el-row>
          <el-col :span="12">
            <el-form-item label="接收人" prop="receivers">
              <el-select v-model="form.receivers" placeholder="请选择接收人" filterable multiple clearable style="width: 100%" :disabled="this.disabled"
                @change='vulTypeChange'>
                <el-option v-for="item in users" :key="item.userName" :label="item.nickName" :value="item.userName" />
              </el-select>
            </el-form-item>
          </el-col>
          
        </el-row>

      </el-form>

@change='vulTypeChange'

javascript 复制代码
vulTypeChange() {
        this.form = { ...this.form }
      },

3)自定义校验方法

javascript 复制代码
 data() {
      // 自定义验证规则
      var picValidator = (rule, value, callback) => {
        if (!this.form.receivers.length) {
          // 一定要写 callBack() 验证完成时调用的回调函数 https://github.com/yiminghe/async-validator
          callback(new Error('请至少选择一个接收人'))
        } else {
          callback()
        }
      }
      return {
。。。。

至此,完美解决el-select复选框表单校验

相关推荐
谢尔登13 分钟前
【React】React 18 并发特性
前端·react.js·前端框架
Joker`s smile16 分钟前
使用React+ant Table 实现 表格无限循环滚动播放
前端·javascript·react.js
国家不保护废物21 分钟前
🌟 React 魔法学院入学指南:从零构建你的第一个魔法阵(项目)!
前端·react.js·架构
然我22 分钟前
从原生 JS 到 React:手把手带你开启 React 业务开发之旅
javascript·react.js·前端框架
import_random24 分钟前
[机器学习]svm支持向量机(优势在哪里)
前端
国家不保护废物25 分钟前
从刀耕火种到现代框架:DOM编程 vs Vue/React 进化史
前端·vue.js·react.js
陈随易25 分钟前
Univer v0.8.0 发布,开源免费版 Google Sheets
前端·后端·程序员
wkj00130 分钟前
QuaggaJS 配置参数详解
java·linux·服务器·javascript·quaggajs
不怎么爱学习的dan30 分钟前
实现 ECharts 多国地区可视化方案
前端
嘉小华31 分钟前
Android Lifecycle 状态同步与分发机制深度解析
前端