0


Element-UI el-select多选表单校验问题

在使用 el-select 多选下拉菜单配置表单校验时, 如果form表单绑定的form对象对应属性值为空字符串或者null(其他未尝试),表单中的多选下拉框会立刻执行校验并弹出校验信息,代码如下:

<el-form :model="form" :rules="settingFormRules">
 <el-form-item prop="level">
   <span slot="label">
     级别<span style="color: #B9BBC4">(支持多选)</span>
   </span>
   <el-select v-model="form.level" multiple placeholder="请选择"  style="width:100%">
     <el-option 
       v-for="item in levelOptions" 
       :key="item.id" 
       :label="item.level_name" 
       :value="item.id" 
     />
   </el-select>
 </el-form-item>
 <el-form-item prop="info">
   <span slot="label">
     信息<span style="color: #B9BBC4">(支持多选)</span>
   </span>
   <el-select v-model="form.info" multiple placeholder="请选择" style="width:100%">
     <el-option 
       v-for="item in infoOptions" 
       :key="item.id" 
       :label="item.infor_name" 
       :value="item.id" 
     />
   </el-select>
 </el-form-item>
</el-form>
data() {
    return {
        form: {
              level: '',
              info: null
        },
        rules: {
            level: [{ required: true, message: '请选择级别', trigger: 'change' }],
            info: [{ required: true, message: '请选择信息', trigger: 'change' }],
        }
    }
}

正确方式如下: 将多选下拉框对应的属性值默认值设置未空数组即可

data() {
    return {
        form: {
              level: [],
              info: []
        },
        ...
    }
}
标签: vue.js javascript

本文转载自: https://blog.csdn.net/qq_43235503/article/details/130717078
版权归原作者 前端小凯 所有, 如有侵权,请联系我们删除。

“Element-UI el-select多选表单校验问题”的评论:

还没有评论