2024-03-12 记录一个展开数组的方法

来源:本来打算写一个递归展开,突然有点懒得写就随便问了下GPT,然后看到AI提供的展开多维数组的案例,借鉴改造了一下
注意需要克隆原数组,堆栈地址的影响

展开树状结构数组

const expendArray = (data: any[]) => {
  const cloneData = cloneDeep(data);
  const result = [];
  // 以原数组的长度作为循环条件,当所有值被删除后,长度为0,条件判断为false
  while(cloneData?.length) {
    // shift() 删除数组的第一个元素并且返回被删除的元素
    const item = cloneData.shift();
    if(item?.children && item?.children?.length) {
      // 如果该元素存在子项,则展开并追加到元素组头部
      cloneData.unshift(...item?.children);
      // 可有可无,删除children属性保持新数组的干净(个人)
      delete item.children;
    }
    // 添加到新数组
    result.push(item);
  }
  return result;
}

展开多维数组

const expendArray = (data: any[]) => {
  const cloneData = cloneDeep(data);
  const result = [];
  while(cloneData?.length) {
    const item = cloneData.shift();
    if(Array.isArray(item)) {
      cloneData.unshift(...item);
    } else {
      result.push(item);
    }
  }
  return result;
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容