【代码优化】IoT: 场景联动彻底修复索引重用问题

This commit is contained in:
puhui999
2025-03-29 14:34:56 +08:00
parent f52f4bcc36
commit c8fce1e254
2 changed files with 12 additions and 3 deletions

View File

@ -72,6 +72,7 @@ interface TriggerCondition {
// 触发器配置
interface TriggerConfig {
key: any // 解决组件索引重用
type: number // 触发类型
productKey: string // 产品标识
deviceNames: string[] // 设备名称数组
@ -98,6 +99,7 @@ interface ActionAlert {
// 执行器配置
interface ActionConfig {
key: any // 解决组件索引重用
type: number // 执行类型
deviceControl?: ActionDeviceControl // 设备控制
alert?: ActionAlert // 告警执行

View File

@ -35,7 +35,7 @@
<el-divider content-position="left">触发器配置</el-divider>
<device-listener
v-for="(trigger, index) in formData.triggers"
:key="`trigger-${index}-${Date.now()}`"
:key="trigger.key"
:model-value="trigger"
@update:model-value="(val) => (formData.triggers[index] = val)"
class="mb-10px"
@ -52,7 +52,7 @@
<el-divider content-position="left">执行器配置</el-divider>
<action-executor
v-for="(action, index) in formData.actions"
:key="`action-${index}-${Date.now()}`"
:key="action.key"
:model-value="action"
@update:model-value="(val) => (formData.actions[index] = val)"
class="mb-10px"
@ -88,6 +88,7 @@ import {
TriggerConfig
} from '@/api/iot/rule/scene/scene.types'
import ActionExecutor from './components/action/ActionExecutor.vue'
import { generateUUID } from '@/utils'
/** IoT 场景联动表单 */
defineOptions({ name: 'IotRuleSceneForm' })
@ -115,6 +116,7 @@ const formRef = ref() // 表单 Ref
/** 添加触发器 */
const addTrigger = () => {
formData.value.triggers.push({
key: generateUUID(), // 解决组件索引重用
type: IotRuleSceneTriggerTypeEnum.DEVICE,
productKey: '',
deviceNames: [],
@ -135,6 +137,7 @@ const removeTrigger = (index: number) => {
/** 添加执行器 */
const addAction = () => {
formData.value.actions.push({
key: generateUUID(), // 解决组件索引重用
type: IotRuleSceneActionTypeEnum.DEVICE_CONTROL
} as ActionConfig)
}
@ -153,7 +156,11 @@ const open = async (type: string, id?: number) => {
if (id) {
formLoading.value = true
try {
formData.value = await RuleSceneApi.getRuleScene(id)
const data = (await RuleSceneApi.getRuleScene(id)) as IotRuleScene
// 解决组件索引重用
data.triggers?.forEach((item) => (item.key = generateUUID()))
data.actions?.forEach((item) => (item.key = generateUUID()))
formData.value = data
} finally {
formLoading.value = false
}