element ui form 行内错误提示

10 篇文章 0 订阅
<template>
  <div id="app" style="padding: 50px;">
    <el-form :model="ruleForm" :rules="rules" :inline-message="true" label-position="right" size="small" ref="ruleForm" label-width="100px" class="demo-ruleForm">
      <el-form-item label="活动名称" prop="name" >
        <template v-slot:label>活动名称
            <el-tooltip class="item" effect="dark" 
                content="Right Center 提示文字" 
                placement="right">
                <span class="el-icon-info"></span>
            </el-tooltip>
        </template>
        <el-input style="width: 800px;" v-model="ruleForm.name"></el-input>
        <!-- 
          自自定义错误提示
          <span slot="error" slot-scope="scope" class="el-form-item__error" style="display: inline-block;">
          {{ scope.error }}
        </span> 
        -->
      </el-form-item>
      <el-form-item label="活动区域" prop="region">
        <el-select  style="width: 800px;"  v-model="ruleForm.region" placeholder="请选择活动区域">
          <el-option label="区域一" value="shanghai"></el-option>
          <el-option label="区域二" value="beijing"></el-option>
        </el-select>
      </el-form-item>
      <!-- <el-form-item label="活动时间" required>
        <el-col :span="11">
          <el-form-item prop="date1">
            <el-date-picker type="date" placeholder="选择日期" v-model="ruleForm.date1" style="width: 100%;"></el-date-picker>
          </el-form-item>
        </el-col>
        <el-col :span="11">
          <el-form-item prop="date2">
            <el-time-picker placeholder="选择时间" v-model="ruleForm.date2" style="width: 100%;"></el-time-picker>
          </el-form-item>
        </el-col>
      </el-form-item> -->
      <el-form-item label="即时配送" prop="delivery">
        <el-switch v-model="ruleForm.delivery"></el-switch>
      </el-form-item>
      <el-form-item label="活动性质" prop="type">
        <span>
          <el-checkbox-group v-model="ruleForm.type" style="display: inline-block;width: 800px;" >
            <el-checkbox label="美食/餐厅线上活动" name="type"></el-checkbox>
            <el-checkbox label="地推活动" name="type"></el-checkbox>
            <el-checkbox label="线下主题活动" name="type"></el-checkbox>
            <el-checkbox label="单纯品牌曝光" name="type"></el-checkbox>
          </el-checkbox-group>
        </span>
      </el-form-item>
      <el-form-item label="特殊资源" prop="resource">
        <el-radio-group v-model="ruleForm.resource"  style="width: 800px;">
          <el-radio label="线上品牌商赞助"></el-radio>
          <el-radio label="线下场地免费"></el-radio>
        </el-radio-group>
      </el-form-item>
      <el-form-item label="姓名" prop="obj.name">
        <el-checkbox-group v-model="ruleForm.obj.name" style="display: inline-block;width: 800px;">
          <el-checkbox label="美食/餐厅线上活动" name="type"></el-checkbox>
          <el-checkbox label="地推活动" name="type"></el-checkbox>
          <el-checkbox label="线下主题活动" name="type"></el-checkbox>
          <el-checkbox label="单纯品牌曝光" name="type"></el-checkbox>
        </el-checkbox-group>
      </el-form-item>
      <el-form-item label="姓名" prop="obj.haha.val">
        <el-input v-model="ruleForm.obj.haha.val" style="width: 800px;">
        </el-input>
      </el-form-item>
      <el-form-item label="活动形式" prop="desc">
        <el-input type="textarea" v-model="ruleForm.desc" style="width: 800px;"></el-input>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="submitForm('ruleForm')">立即创建</el-button>
        <el-button @click="resetForm('ruleForm')">重置</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>

export default {
  name: 'app',
  data() {
      return {
        ruleForm: {
          name: '',
          region: '',
          date1: '',
          date2: '',
          delivery: false,
          type: [],
          resource: '',
          desc: '',
          obj: {
            name: [],
            haha:{
              val: ""
            }
          }
        },
        rules: {
          name: [
            { required: true, message: '请输入活动名称', trigger: 'blur' },
            { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
          ],
          region: [
            { required: true, message: '请选择活动区域', trigger: 'change' }
          ],
          date1: [
            { type: 'date', required: true, message: '请选择日期', trigger: 'change' }
          ],
          date2: [
            { type: 'date', required: true, message: '请选择时间', trigger: 'change' }
          ],
          type: [
            { type: 'array', required: true, message: '请至少选择一个活动性质', trigger: 'change' }
          ],
          resource: [
            { required: true, message: '请选择活动资源', trigger: 'change' }
          ],
          desc: [
            { required: true, message: '请填写活动形式', trigger: 'blur' }
          ],
          obj:{
            name: [
              {  type: 'array', required: true, message: '请至少选择一个', trigger: 'change' },
            ],
            haha: {
              val: { required: true, message: '请填写活动形式', trigger: ["change"] }
            }
          }
        }
      };
    },
    methods: {
      submitForm(formName) {
        this.$refs[formName].validate((valid) => {
          if (valid) {
            alert('submit!');
          } else {
            return false;
          }
        });
      },
      resetForm(formName) {
        this.$refs[formName].resetFields();
      }
    }
}
</script>

 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Element UI提供了一种行内校验的方法,可以在表单中的每个输入项旁边显示错误提示信息。要实现行内校验,你需要使用`el-form`组件和`el-form-item`组件来包裹表单控件,并使用`rules`属性来指定校验规则。下面是一个示例: ```html <template> <el-form :model="form" :rules="rules" ref="form" inline> <el-form-item label="用户名" prop="username"> <el-input v-model="form.username"></el-input> </el-form-item> <el-form-item label="密码" prop="password"> <el-input type="password" v-model="form.password"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </template> <script> export default { data() { return { form: { username: '', password: '' }, rules: { username: [ { required: true, message: '请输入用户名', trigger: 'blur' }, // 其他校验规则 ], password: [ { required: true, message: '请输入密码', trigger: 'blur' }, // 其他校验规则 ] } } }, methods: { submitForm() { this.$refs.form.validate(valid => { if (valid) { // 校验通过,提交表单 // ... } else { // 校验不通过,显示错误提示 return false; } }); } } } </script> ``` 在上面的示例中,我们使用了`el-form`组件来包裹整个表单,并设置了`inline`属性以实现行内布局。每个表单控件都被`el-form-item`组件包裹,通过`prop`属性指定了对应的字段名。在`rules`中定义了每个字段的校验规则。 `submitForm`方法中调用了`validate`方法来进行校验,如果校验通过,则执行提交表单的逻辑,否则显示错误提示信息。 希望这个示例对你有帮助!如有更多问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值