el-form表单根据条件触发校验

javascript 复制代码
<template>
  <div>
    <el-form :model="ruleForm" :rules="rules" ref="ruleForm">

      <el-form-item label="活动区域" prop="resource">
        <el-radio-group v-model="ruleForm.resource">
          <el-radio :label="1">线上品牌商赞助</el-radio>
          <el-radio :label="2">线下场地免费</el-radio>
        </el-radio-group>
      </el-form-item>

      <el-form-item label="活动名称" prop="name" :required="this.ruleForm.resource === 1">
        <el-input v-model="ruleForm.name" class="w-220"></el-input>
      </el-form-item>
    </el-form>
    <el-button type="primary" @click="btn">提交</el-button>
  </div>
</template>

<script>
export default {
  data () {
    // 触发校验
    const validatePass = (rule, value, callback) => {
      if (this.ruleForm.resource === 1 && !value) {
        return callback(new Error('不能为空'));
      } else {
        callback()
      }
    }
    return {
      ruleForm: {
        resource: '',
        name: ''
      },
      rules: {
        resource: [
          { required: true, message: '请选择', trigger: 'change' }
        ],
        name: [
          { validator: validatePass, trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    //  提交
    btn () {
      this.$refs.ruleForm.validate((valid) => {
        if (valid) {
          console.log('成功')
        }
      })
    }
  }
}
</script>

<style>
</style>
相关推荐
林深现海14 分钟前
Jetson Orin nano/nx刷机后无法打开chrome/firefox浏览器
前端·chrome·firefox
EchoEcho26 分钟前
深入理解 Vue.js 渲染机制:从声明式到虚拟 DOM 的完整实现
vue.js
黄诂多28 分钟前
APP原生与H5互调Bridge技术原理及基础使用
前端
前端市界31 分钟前
用 React 手搓一个 3D 翻页书籍组件,呼吸海浪式翻页,交互体验带感!
前端·架构·github
文艺理科生33 分钟前
Nginx 路径映射深度解析:从本地开发到生产交付的底层哲学
前端·后端·架构
千寻girling33 分钟前
主管:”人家 Node 框架都用 Nest.js 了 , 你怎么还在用 Express ?“
前端·后端·面试
C澒42 分钟前
Vue 项目渐进式迁移 React:组件库接入与跨框架协同技术方案
前端·vue.js·react.js·架构·系统架构
xiaoxue..1 小时前
合并两个升序链表 与 合并k个升序链表
java·javascript·数据结构·链表·面试
清山博客1 小时前
OpenCV 人脸识别和比对工具
前端·webpack·node.js
要加油哦~1 小时前
AI | 实践教程 - ScreenCoder | 多agents前端代码生成
前端·javascript·人工智能