用数组遍历出来的页面,随节点创建的ref存储在数据仓库中,如果数据删除,页面相关节点也会删除,数据仓库中随节点创建的ref会不会也同时删除

在 Vue.js 里,当使用数组遍历渲染页面元素并把 ref 存储到数据仓库(例如使用 Pinia 作为状态管理库)时,若数组数据删除使得页面上相关 DOM 节点移除,数据仓库里对应的 ref 不会自动删除。下面详细说明原因及解决办法。

原因分析

  • 数据仓库的独立性:数据仓库(如 Pinia)是独立于 DOM 的状态管理系统,它不会自动感知 DOM 节点的变化。即便 DOM 节点被移除,数据仓库里存储的 ref 依然存在。
  • Vue 的响应式更新:Vue 的响应式系统主要关注数据的变化并更新 DOM,但不会自动清理数据仓库里的 ref。

解决办法

要保证数据仓库里的 ref 和页面上的 DOM 节点同步,需要在数据更新时手动清理 ref。以下是一个示例:

javascript 复制代码
import { defineStore } from 'pinia';

export const useSlideState = defineStore('slideState', {
    state: () => ({
        allDataObj: [
            { title: '本人信息', id: 0, flag: 1, comIndex: 1 },
            { title: '家庭信息', id: 1, flag: 1, comIndex: 2 },
            { title: '工作信息', id: 2, flag: 1, comIndex: 3 },
            { title: '其他信息', id: 3, flag: 1, comIndex: 4 },
        ],
        slideFlag: { table1: 0, table2: 0, table3: 0, table4: 0 },
        slideState: {
            table1: 0,
            table2: 0,
            table3: 0,
            table4: 0,
        },
        all: {
            table1: [{ a: 1, b: 2 }, { c: 3, d: 4 }],
            table2: [{ a: 1, b: 3 }]
        },
        // 假设这里存储 ref
        itemRefs: [] 
    }),
    actions: {
        removeItem(index) {
            // 删除数组中的数据
            this.allDataObj.splice(index, 1); 
            // 手动清理对应的 ref
            this.itemRefs.splice(index, 1); 
        }
    }
});

代码解释

  • itemRefs:在状态里添加一个数组 itemRefs 来存储 ref。
  • removeItem 方法:在删除 allDataObj 数组里的数据时,同时使用 splice 方法删除 itemRefs 数组中对应位置的 ref。

总结

数据仓库里存储的 ref 不会随 DOM 节点的删除自动清理,需要在数据更新时手动处理。

相关推荐
chat2tomorrow19 小时前
数据仓库是什么?数据仓库的前世今生 (数据仓库系列一)
大数据·数据库·数据仓库·低代码·华为·spark·sql2api
shouwangV61 天前
hive执行CTAS报错“Hive Runtime Error while processing row”
数据仓库·hive·hadoop
一个天蝎座 白勺 程序猿1 天前
大数据(4.1)Hive架构设计与企业级实战:从内核原理到性能巅峰优化,打造高效数据仓库
数据仓库·hive·hadoop
想要变瘦的小码头3 天前
hive数据仓库
数据仓库·hive·hadoop
Tipray20063 天前
天锐蓝盾终端安全防护——企业终端设备安全管控
数据仓库
小技工丨4 天前
【数据仓库】湖仓一体的核心建模理论
数据仓库
RestCloud4 天前
ETL中数据转换的三种处理方式
数据仓库·etl·数字化转型·数据转换·api管理
小技工丨4 天前
【数据仓库】星型模型和维度建模什么区别?
大数据·数据仓库
徐一闪_BigData4 天前
数仓开发那些事(11)
数据仓库·hive·yarn