new Map()+Array.from()整理elementPlus的级联器数据

1、假设有数据:

javascript 复制代码
// 规则类型
const eventTypeStatus = [
    { label: '数据规则', parentId: null, value: 'data' },
    { label: '事件规则', parentId: null, value: 'event' },
]

// 规则来源
const eventSourceStatus = [
    { label: '数据-1', parentId: 'data', value: 'data-001' },
    { label: '数据-2', parentId: 'data', value: 'data-002' },
    { label: '数据-3', parentId: 'data', value: 'data-003' },
    { label: '事件-1', parentId: 'event', value: 'event-001' },
    { label: '事件-2', parentId: 'event', value: 'event-002' },
    { label: '事件-3', parentId: 'event', value: 'event-003' },
]

2、Cascader 级联选择器的数据格式:

3、把1中的 eventTypeStatus 和 eventSourceStatus 数据整理成级联器需要的options数据格式

1、定义方法 buildCascaderOptions

javascript 复制代码
// 将 eventTypeStatus 和 eventSourceStatus 整理为 cascader 所需的 options 结构
const buildCascaderOptions = (eventTypeStatus , eventSourceStatus) => {
  // 步骤1:将 eventTypeStatus 转换为 map,便于快速查找
  const parentMap = new Map();
  console.log('parentMap', parentMap);
  eventTypeStatus.forEach(item => {
    console.log('eventTypeStatus-item:', item);
    
    parentMap.set(item.value, {
      value: item.value,
      label: item.label,
      children: []
    });
    console.log('parentMap', parentMap);
    
  });

  // 步骤2:遍历 eventSourceStatus,将每个 child 添加到对应的 parent 的 children 中
  eventSourceStatus.forEach(child => {
    const parent = parentMap.get(child.parentCd);
    if (parent) {
      parent.children.push({
        value: child.value,
        label: child.label,
        parentCd: child.parentCd // 可选保留
      });
    } else {
      console.warn(`未找到父节点 ${child.parentCd},无法挂载子项:${child.label}`);
    }
  });

  // 步骤3:将 map 中的所有值转换为数组
  console.log('数组', Array.from(parentMap.values()));
  
  return Array.from(parentMap.values());
};

2、调用 buildCascaderOptions 生成 options

javascript 复制代码
onMounted(() => {
    // 规则类型
    const eventTypeStatus = [
        { label: '数据规则', parentId: null, value: 'data' },
        { label: '事件规则', parentId: null, value: 'event' },
    ]

    // 规则来源
    const eventSourceStatus = [
        { label: '数据-1', parentId: 'data', value: 'data-001' },
        { label: '数据-2', parentId: 'data', value: 'data-002' },
        { label: '数据-3', parentId: 'data', value: 'data-003' },
        { label: '事件-1', parentId: 'event', value: 'event-001' },
        { label: '事件-2', parentId: 'event', value: 'event-002' },
        { label: '事件-3', parentId: 'event', value: 'event-003' },
    ]

    options.value = buildCascaderOptions(eventTypeStatus , eventSourceStatus);
})

3、调用 options

html 复制代码
<el-col :span="7">
   <el-form-item label="事件来源" style="font-weight: 600;width: 100%">
      <el-cascader v-model="eventSourceCascader" :options="options" @change="handleChange"              />
   </el-form-item>
</el-col>
相关推荐
CappuccinoRose37 分钟前
HTML语法学习文档(五)
前端·html·html5·表单
2401_858286111 小时前
OS55.【Linux】理解信号量(不是信号)
linux·运维·服务器·计数器·信号量
硅基动力AI2 小时前
如何判断一个关键词值不值得做?
java·前端·数据库
S-码农2 小时前
Linux进程通信——消息队列
linux
yq1982043011562 小时前
使用Django构建视频解析网站 从Naver视频下载器看Web开发全流程
前端·django·音视频
零基础的修炼3 小时前
Linux网络---数据链路层
linux·服务器·网络
李明卫杭州3 小时前
在 JavaScript 中,生成器函数(Generator Function)
前端·javascript
楼田莉子3 小时前
Linux学习:线程的同步与互斥
linux·运维·c++·学习
Lethehong3 小时前
从安装到实测:基于 Claude Code + GLM-4.7 的前端生成与评测实战
前端
恋猫de小郭3 小时前
iOS + AI ,国外一个叫 Rork Max 的项目打算替换掉 Xcode
android·前端·flutter