elementui 表单规则

复制代码
<script setup lang="ts">
import type { FormInstance } from 'element-plus'

const configuretion_form = reactive({
  serialport_name: '',
  slave_count: 1,
  run_switch_value: false
})
const configuretion_form_ref = ref()
const configuretion_form_rules = {
  serialport_name: [{
    required: true,
    message: '需要选择一个串口',
    trigger: 'change'
  }]
}

async function run_switch_click(formEl: FormInstance | undefined) {
  if (!formEl) return

  formEl.validate(async valid => {
    // 验证失败
    if (!valid) {
      console.log('验证失败')
      configuretion_form.run_switch_value = false
      return
    }
     console.log('验证成功')
  })
}

const serialport_name_table = Array.from({ length: 10000 }).map((_, idx) => ({
  value: `${idx + 1}`,
  label: `${idx + 1}`,
}))
</script>

<template>
  <el-container>
    <el-aside>
      <el-form ref="configuretion_form_ref" :model="configuretion_form" :rules="configuretion_form_rules"
        :disabled="configuretion_form.run_switch_value" label-width="70px">

        <el-form-item label="串口名" prop="serialport_name">
          <el-select-v2 v-model="configuretion_form.serialport_name" :options="serialport_name_table" />
        </el-form-item>

        <el-form-item label="串口参数">
          <el-text>9600bps 8n1 rtu</el-text>
        </el-form-item>

        <el-form-item label="从机数">
          <el-input-number v-model="configuretion_form.slave_count" :min="1" :max="100" />
        </el-form-item>

        <el-form :model="configuretion_form" label-width="70px">
          <el-form-item label="运行">
            <el-switch v-model="configuretion_form.run_switch_value" @click="run_switch_click(configuretion_form_ref)" />
          </el-form-item>
        </el-form>

      </el-form>
    </el-aside>

    <el-main>Main</el-main>
  </el-container>
</template>

configuretion_form_rules 和 configuretion_form 里对应项的名字要一致,比如这里的 serialport_name

相关推荐
2501_9437823515 小时前
【共创季稿事节】猜数字游戏:二分法思维与交互式反馈
前端·游戏·microsoft·harmonyos·鸿蒙·鸿蒙系统
GV191rLvq15 小时前
基于Socket实现的最简单的Web服务器【ASP.NET原理分析】
服务器·前端·asp.net
吠品15 小时前
LangChain 里 tool_call_id 为空?一次 MCP 工具集成的排查记录
前端
柒和远方16 小时前
Phase 7.4 学习博客:为什么多 API 项目需要 Swagger / OpenAPI
前端·后端·架构
张龙68716 小时前
拼多多开放平台对接踩坑实录:从 CLIENT_ID 配置到 MD5 签名算法的完整填坑指南
前端
GuWenyue16 小时前
提示词彻底过时?一套上下文工程方案,3步让LLM落地生产,代码直接复用
前端·javascript·人工智能
柒和远方16 小时前
Phase 7.3 复盘:后台任务不只是“扔进队列”,还要能被看见
前端·后端·架构
2501_9437823516 小时前
【共创季稿事节】 倒计时器:时分秒选择器与定时器的协同工作
前端·华为·harmonyos·鸿蒙·鸿蒙系统
奶油mm16 小时前
公司技术债堆积如山,我一人之力用 Vue3 偷换了整个前端架构
前端·vue.js