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

相关推荐
童先生1 小时前
Nginx + Vue/React 前端 + API:防止路径混淆漏洞与跨域问题实战分享
前端·vue.js·nginx
黑夜照亮前行的路2 小时前
JavaScript 性能优化实战技术指南
javascript·性能优化
Stringzhua3 小时前
Vue数据的变更操作与表单数据的收集【6】
前端·javascript·vue.js
万少4 小时前
可可图片编辑 HarmonyOS 上架应用分享
前端·harmonyos
你的人类朋友4 小时前
git常见操作整理(持续更新)
前端·git·后端
无羡仙4 小时前
Webpack 核心实战:从零搭建支持热更新与 Babel 转译的现代前端环境
前端·webpack·前端框架
乐~~~4 小时前
el-date-picker type=daterange 日期范围限制
javascript·vue.js·elementui
你的人类朋友4 小时前
git中的Fast-Forward是什么?
前端·git·后端
初遇你时动了情4 小时前
uniapp vue3 ts自定义底部 tabbar菜单
前端·javascript·uni-app
JarvanMo5 小时前
天塌了?Flutter工程总监跑去苹果了?
前端