【elementUI】form表单rules没生效

关键原则是: 中的 prop 值必须与验证规则对象中的键名完全一致 。对于嵌套属性如 info.modelId,需要在两个地方都指定完整的路径。

javascript 复制代码
<template>
  <el-form :model="editForm" ref="editRef" :rules="editFormRules">
    <el-form-item prop="sceneId" :label="t('setting.scene')">
      <el-select
        v-model="editForm.sceneId"
        :placeholder="t('common.placeholderSelect')"
        @change="handleSceneChange"
      >
        <el-option
          v-for="item in appStore.envLists"
          :key="item._id"
          :label="item.name"
          :value="item._id"
        />
      </el-select>
    </el-form-item>

    <el-form-item prop="info.modelId" :label="t('scene.menu.file')">
      <el-select v-model="editForm.info.modelId" :placeholder="t('common.placeholderSelect')">
        <el-option
          v-for="item in modelOptions"
          :key="item.modelId"
          :label="item.modelName"
          :value="item.modelId"
        />
      </el-select>
    </el-form-item>

    <el-form-item prop="type" :label="t('common.type')">
      <el-select v-model="editForm.type" :placeholder="t('common.placeholderSelect')">
        <el-option
          v-for="type in robotTypes"
          :key="type.value"
          :label="type.label"
          :value="type.value"
        />
      </el-select>
    </el-form-item>

    <el-form-item prop="info.sn" :label="t('robot.robot_no')">
      <el-input v-model="editForm.info.sn" />
    </el-form-item>

    <el-form-item prop="info.name" :label="t('robot.robot_name')">
      <el-input v-model="editForm.info.name" />
    </el-form-item>

    <el-form-item>
      <el-button @click="handleCancle">{{ t('common.cancel') }}</el-button>
      <el-button type="primary" @click="submitForm">
        {{ t('common.save') }}
      </el-button>
    </el-form-item>
  </el-form>
</template>

<script setup lang="jsx">
const editForm = ref({
  sceneId: undefined,
  type: undefined,
  info: {
    sn: undefined,
    name: undefined,
    modelId: undefined,
  },
});
// 模型选择框
const modelOptions = ref([]);
let robotTypes = dictStore.ROBOT_TYPES;

const editFormRules = ref({
  'sceneId': [{ required: true, message: t('rules.isRequired'), trigger: 'change' }],
  'info.modelId': [{ required: true, message: t('rules.isRequired'), trigger: 'change' }],
  type: [{ required: true, message: t('rules.isRequired'), trigger: 'change' }],
    'info.sn': [{ required: true, message: t('rules.isRequired'), trigger: 'blur' }],
});

const editRef = ref(null);
相关推荐
云飞云共享云桌面19 小时前
传统工作站 vs 云飞云共享云桌面:制造业设计云桌面选型深度对比
运维·服务器·前端·网络·3d·架构·制造
UXbot20 小时前
如何选择适合公司项目的UI设计工具?企业选型指南
前端·低代码·ui·团队开发·原型模式·设计规范·web app
llz_11220 小时前
web-第四次课后作业
前端·spring boot·web
武清伯MVP21 小时前
前端跨域方案大合集
前端·javascript
小刘|21 小时前
Spring AI Alibaba 集成和风天气 API 实战
java·服务器·前端
星星在线1 天前
我是怎么把页面图片流量砍掉一半的
前端·javascript
木叶子---1 天前
前端打包出错
前端·人工智能·tensorflow
JAVA面经实录9171 天前
前端系统化学习计划表(含完整知识思维导图)
前端·学习
本末倒置1831 天前
开发了一个所见所得的md编辑器,致敬Typora大佬
前端
kyriewen1 天前
TypeScript 高级类型:我用 infer 写了一个类型安全的 EventBus,终于搞懂了泛型约束
前端·javascript·typescript