diff --git a/core/core-frontend/src/components/data-visualization/canvas/CanvasCore.vue b/core/core-frontend/src/components/data-visualization/canvas/CanvasCore.vue index ecd562365f..6857004247 100644 --- a/core/core-frontend/src/components/data-visualization/canvas/CanvasCore.vue +++ b/core/core-frontend/src/components/data-visualization/canvas/CanvasCore.vue @@ -349,7 +349,7 @@ const coordinates = ref([]) //坐标点集合 let lastTask = undefined let isOverlay = false //是否正在交换位置 -let moveTime = 200 //移动动画时间 +let moveTime = 100 //移动动画时间 const itemMaxY = ref(0) let itemMaxX = 0 @@ -874,6 +874,11 @@ function removeItemById(componentId) { removeItem(index) } }) + if (!isMainCanvas(canvasId.value)) { + nextTick(() => { + canvasInit() + }) + } } } diff --git a/core/core-frontend/src/custom-component/de-tabs/Component.vue b/core/core-frontend/src/custom-component/de-tabs/Component.vue index 5c5177dfd8..3d21ea46b8 100644 --- a/core/core-frontend/src/custom-component/de-tabs/Component.vue +++ b/core/core-frontend/src/custom-component/de-tabs/Component.vue @@ -335,8 +335,9 @@ const componentMoveIn = component => { component.style.left = 0 component.style.top = 0 tabItem.componentData.push(component) + refInstance.addItemBox(component) //在适当的时候初始化布局组件 nextTick(() => { - refInstance.addItemBox(component) //在适当的时候初始化布局组件 + refInstance.canvasInitImmediately() }) } } else { diff --git a/core/core-frontend/src/views/canvas/DeCanvas.vue b/core/core-frontend/src/views/canvas/DeCanvas.vue index dc13acdaf0..dc023710f4 100644 --- a/core/core-frontend/src/views/canvas/DeCanvas.vue +++ b/core/core-frontend/src/views/canvas/DeCanvas.vue @@ -133,6 +133,10 @@ const handleMouseDown = e => { } } +const canvasInitImmediately = () => { + cyGridster.value.canvasInit() +} + const canvasInit = (isFistLoad = true) => { if (canvasActive.value) { renderState.value = true @@ -218,6 +222,7 @@ const moveOutFromTab = component => { componentData: componentData.value }) addItemBox(component) + canvasInit() }, 500) } @@ -272,6 +277,8 @@ watch( defineExpose({ addItemBox, + canvasInit, + canvasInitImmediately, getBaseMatrixSize })