From 6c26363653eff403da477c8681fa3723d87f4b99 Mon Sep 17 00:00:00 2001 From: Jay <csj123456> Date: 星期五, 01 十一月 2024 11:51:49 +0800 Subject: [PATCH] tag新增导入导出功能 --- src/views/data/channel/modbus/ModBusDeviceForm.vue | 89 +++++++++++++++++++++++++++----------------- 1 files changed, 55 insertions(+), 34 deletions(-) diff --git a/src/views/data/channel/modbus/ModBusDeviceForm.vue b/src/views/data/channel/modbus/ModBusDeviceForm.vue index ad17a36..ee57f6a 100644 --- a/src/views/data/channel/modbus/ModBusDeviceForm.vue +++ b/src/views/data/channel/modbus/ModBusDeviceForm.vue @@ -10,62 +10,62 @@ <el-row> <el-col :span="12"> <el-form-item label="设备名称" prop="name"> - <el-input v-model="formData.name" placeholder="请输入设备名称" /> + <el-input v-model="formData.name" placeholder="请输入设备名称"/> </el-form-item> </el-col> </el-row> <el-row> <el-col :span="12"> <el-form-item label="IP地址" prop="address"> - <el-input v-model="formData.address" placeholder="请输入IP地址" /> + <el-input v-model="formData.address" placeholder="请输入IP地址"/> </el-form-item> </el-col> <el-col :span="12"> <el-form-item label="端口" prop="port"> - <el-input v-model="formData.port" placeholder="请输入端口" /> + <el-input v-model="formData.port" placeholder="请输入端口"/> </el-form-item> </el-col> </el-row> <el-row> <el-col :span="12"> <el-form-item label="不活动超时(ms)" prop="connectInactivityTimeout"> - <el-input v-model="formData.connectInactivityTimeout" placeholder="请输入不活动超时" /> + <el-input v-model="formData.connectInactivityTimeout" placeholder="请输入不活动超时"/> </el-form-item> </el-col> <el-col :span="12"> <el-form-item label="重连超时(ms)" prop="reconnectInterval"> - <el-input v-model="formData.reconnectInterval" placeholder="请输入重连超时" /> + <el-input v-model="formData.reconnectInterval" placeholder="请输入重连超时"/> </el-form-item> </el-col> </el-row> <el-row> <el-col :span="12"> <el-form-item label="重试次数" prop="attemptsBeforeTimeout"> - <el-input v-model="formData.attemptsBeforeTimeout" placeholder="请输入重试次数" /> + <el-input v-model="formData.attemptsBeforeTimeout" placeholder="请输入重试次数"/> </el-form-item> </el-col> <el-col :span="12"> <el-form-item label="重试间隔(ms)" prop="waitToRetryMilliseconds"> - <el-input v-model="formData.waitToRetryMilliseconds" placeholder="请输入重试间隔" /> + <el-input v-model="formData.waitToRetryMilliseconds" placeholder="请输入重试间隔"/> </el-form-item> </el-col> </el-row> <el-row> <el-col :span="12"> <el-form-item label="读超时(ms)" prop="readTimeout"> - <el-input v-model="formData.readTimeout" placeholder="请输入读超时" /> + <el-input v-model="formData.readTimeout" placeholder="请输入读超时"/> </el-form-item> </el-col> <el-col :span="12"> <el-form-item label="写超时(ms)" prop="writeTimeout"> - <el-input v-model="formData.writeTimeout" placeholder="请输入写超时" /> + <el-input v-model="formData.writeTimeout" placeholder="请输入写超时"/> </el-form-item> </el-col> </el-row> <el-row> <el-col :span="12"> <el-form-item label="是否使用优化" prop="useOptimizedBlockRead"> - <el-input v-model="formData.useOptimizedBlockRead" placeholder="请输入是否使用优化" /> + <el-input v-model="formData.useOptimizedBlockRead" placeholder="请输入是否使用优化"/> </el-form-item> </el-col> </el-row> @@ -77,13 +77,12 @@ </Dialog> </template> <script lang="ts" setup> - import { DICT_TYPE, getIntDictOptions } from '@/utils/dict' import * as ModBusApi from '@/api/data/channel/modbus' - import { CommonStatusEnum } from '@/utils/constants' + import {isIP, isPositiveInteger} from '@/utils/validate' - defineOptions({ name: 'DataModBusDeviceForm' }) + defineOptions({name: 'DataModBusDeviceForm'}) - const { t } = useI18n() // 国际化 + const {t} = useI18n() // 国际化 const message = useMessage() // 消息弹窗 const dialogVisible = ref(false) // 弹窗的是否展示 const dialogTitle = ref('') // 弹窗的标题 @@ -94,21 +93,43 @@ name: undefined, address: undefined, port: undefined, - connectInactivityTimeout: undefined, - reconnectInterval: undefined, - attemptsBeforeTimeout: undefined, - waitToRetryMilliseconds: undefined, - readTimeout: undefined, - writeTimeout: undefined, - useOptimizedBlockRead: undefined, - projectReference: undefined + connectInactivityTimeout: "", + reconnectInterval: "5000", + attemptsBeforeTimeout: "3", + waitToRetryMilliseconds: "250", + readTimeout: "3000", + writeTimeout: "3000", + useOptimizedBlockRead: "true", + projectReference: '' }) + const validateIP = (rule, value, callback) => { + if (!isIP(value)) { + callback(new Error('IP地址不正确')) + } else { + callback() + } + } + const validateNum = (rule, value, callback) => { + if (!isPositiveInteger(value)) { + callback(new Error('格式不正确')) + } else { + callback() + } + } + const formRules = reactive({ - name: [{ required: true, message: '设备名称不能为空', trigger: 'blur' }], - address: [{ required: true, message: 'IP地址不能为空', trigger: 'blur' }], - port: [{ required: true, message: '端口不能为空', trigger: 'blur' }] + name: [{required: true, message: '设备名称不能为空', trigger: 'blur'}], + address: [ + {required: true, message: 'IP地址不能为空', trigger: 'blur'}, + {validator: validateIP, trigger: 'blur'} + ], + port: [ + {required: true, message: '端口不能为空', trigger: 'blur'}, + {validator: validateNum, trigger: 'blur'} + ] }) const formRef = ref() // 表单 Ref + /** 打开弹窗 */ const open = async (type: string, id?: number) => { @@ -126,7 +147,7 @@ } } } - defineExpose({ open }) // 提供 open 方法,用于打开弹窗 + defineExpose({open}) // 提供 open 方法,用于打开弹窗 /** 提交表单 */ const emit = defineEmits(['success']) // 定义 success 事件,用于操作成功后的回调 @@ -161,14 +182,14 @@ name: undefined, address: undefined, port: undefined, - connectInactivityTimeout: undefined, - reconnectInterval: undefined, - attemptsBeforeTimeout: undefined, - waitToRetryMilliseconds: undefined, - readTimeout: undefined, - writeTimeout: undefined, - useOptimizedBlockRead: undefined, - projectReference: undefined + connectInactivityTimeout: "", + reconnectInterval: "5000", + attemptsBeforeTimeout: "3", + waitToRetryMilliseconds: "250", + readTimeout: "3000", + writeTimeout: "3000", + useOptimizedBlockRead: "true", + projectReference: '' } formRef.value?.resetFields() } -- Gitblit v1.9.3