<el-form-item label="目录ID" prop="directoryId"> <el-input v-model="form.directoryId" placeholder="请输入目录ID" > </el-input> </el-form-item> export default { rules: { directoryId: [ {required: true, message: "目录id不能为空", trigger: "blur"}, { validator: this.checkDirectoryId, trigger: 'blur' }// 在失去焦点时进行校验 ], directoryName: [ {required: true, message: "目录名称不能为空", trigger: "blur"}, ], //排序不能为空 sort: [ {required: true, message: "排序不能为空", trigger: "blur"}, ], } methods:{ checkDirectoryId(rule, value, callback) { const existingDirectoryIds = []; for (let i = 0; i < this.tableData.length; i++) { existingDirectoryIds.push(this.tableData[i].directoryId); } console.log(existingDirectoryIds) if (existingDirectoryIds.includes(value)) { callback(new Error('该目录ID已存在')); } else { callback(); } } }这段代码为什么在目录id的输入框输入已有的数值,未进行正确的校验呢?
时间: 2024-04-11 14:33:19 浏览: 97
在这段代码中,校验函数`checkDirectoryId`是在失去焦点时触发的,而输入框的校验是在输入时触发的。所以即使输入已有的数值,校验函数并没有被触发,导致没有进行正确的校验。
要解决这个问题,你可以改变校验的触发时机,将校验规则放在输入框的`change`事件中,这样在每次输入数值时都会触发校验函数。你可以将`trigger`属性设置为`change`,修改代码如下:
```javascript
rules: {
directoryId: [
{ required: true, message: "目录id不能为空", trigger: "blur" },
{ validator: this.checkDirectoryId, trigger: "change" } // 在输入时进行校验
],
// 其他规则...
},
```
这样修改后,在输入已有的数值时,校验函数会被正确触发,从而进行正确的校验。
相关问题
<div class="main-container"> <el-card class="form-card"> <template #header> <span>添加新矿石</span> </template> <el-form ref="form" :model="formData" label-width="120px"> <el-form-item label="矿石名称" prop="name"> <el-input v-model="formData.name"></el-input> </el-form-item> <el-form-item label="描述" prop="desc"> <el-input v-model="formData.desc"></el-input> </el-form-item> <el-form-item label="分类" prop="category"> <el-input v-model="formData.category"></el-input> </el-form-item> <el-form-item label="具体信息" prop="additional_info"> <el-input v-model="formData.additional_info"></el-input> </el-form-item> <el-form-item label="发现地点" prop="location"> <el-input v-model="formData.location"></el-input> </el-form-item> <el-form-item label="图片" prop="image"> <input type="file" @change="handleFileChange" /> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </el-card> </div>什么意思
这是一个使用了 Element UI 组件库的 Vue.js 组件,它显示了一个表单,用于添加新的矿石。表单包括矿石名称、描述、分类、具体信息、发现地点和图片等字段。用户可以填写这些信息,并在点击提交按钮后将表单数据提交到后台进行处理。其中,图片字段使用了 HTML5 的 input 标签,允许用户选择本地的一个文件作为图片。
<el-card shadow="never"> <el-divider content-position="left"><h3>创建&编辑邮件模板</h3></el-divider> <el-form label-position="top"> <el-form-item label="邮件名称" prop="name" style="width: 200px"> <el-input v-model="modeData.name"></el-input> </el-form-item> <el-form-item label="模板名称" prop="subject" style="width: 200px"> <el-input v-model="modeData.subject"></el-input> </el-form-item> <el-form-item label="语言" prop="language"> <el-select v-model="modeData.language" placeholder="请选择"> <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value"> </el-option> </el-select> </el-form-item> <el-form-item label="启动/禁用" prop="enable"> <el-switch v-model="modeData.enable" active-text="禁用" inactive-text="启动"> </el-switch> </el-form-item> <el-form-item label="模板配置" prop="value"> <PiEditor v-model="modeData.value" placeholder="请输入" :height="400" /> </el-form-item> <el-button @click="onSubmit">保存</el-button> </el-form> </el-card>请为这段代码布局
可以使用以下代码布局:
```
<template>
<el-card shadow="never">
<el-divider content-position="left">
<h3>创建&编辑邮件模板</h3>
</el-divider>
<el-form label-position="top">
<el-form-item label="邮件名称" prop="name">
<el-input v-model="modeData.name" style="width: 200px" />
</el-form-item>
<el-form-item label="模板名称" prop="subject">
<el-input v-model="modeData.subject" style="width: 200px" />
</el-form-item>
<el-form-item label="语言" prop="language">
<el-select v-model="modeData.language" placeholder="请选择">
<el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value" />
</el-select>
</el-form-item>
<el-form-item label="启动/禁用" prop="enable">
<el-switch v-model="modeData.enable" active-text="禁用" inactive-text="启动" />
</el-form-item>
<el-form-item label="模板配置" prop="value">
<PiEditor v-model="modeData.value" placeholder="请输入" :height="400" />
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">保存</el-button>
</el-form-item>
</el-form>
</el-card>
</template>
```
这样可以使表单更加美观,且易于使用。
阅读全文