JS对象转数组,数组转对象,数组转树

1.对象转树组


const obj = { 0: '男', 1:'女'}
function f(obj) {
 // 创建一个新数组用来保存数据
  let arr=[]
// 通过遍历把对象中的数据转到新创建的数组之中去
  for (let key in obj) {
        //在arr中添加一个对象,对象的中有两个键值对,label:当前项的值,value:当前项的key
    arr.push({label:obj[key],value:key})
  }
// 把新数组return出去这样就可以直接得到数据
  return arr
}
const arr = f(obj) // arr ===>  [{label: '男', value: 0},{label: '女', value: 1}]
console.log(arr);

2.数组转对象

const arr = [{label: '男', value: 0},{label: '女', value: 1}]
function f(arr) {
  // 创建一个新对象用来存储数据
  let m={}
    // 遍历原数组
    arr.forEach(item => {
    // m对象的键:数组每一项的value值,值:每一项的label值
      m[item.value]=item.label
    });
   // 把m对象return出去
  return m
}
const obj = f(arr) // obj ===> {0: '男', 1:'女'}
console.log(obj);

3.数组转树

const data = [
                  {id:"01", name: "张大大", pid:"", job: "项目经理"},
                  {id:"02", name: "小亮", pid:"01", job: "产品leader"},
                  {id:"03", name: "小美", pid:"01", job: "UIleader"},
                  {id:"04", name: "老马", pid:"01", job: "技术leader"},
                  {id:"05", name: "老王", pid:"01", job: "测试leader"},
                  {id:"06", name: "老李", pid:"01", job: "运维leader"},
                  {id:"07", name: "小丽", pid:"02", job: "产品经理"},
                  {id:"08", name: "大光", pid:"02", job: "产品经理"},
                  {id:"09", name: "小高", pid:"03", job: "UI设计师"},
                  {id:"10", name: "小刘", pid:"04", job: "前端工程师"},
                  {id:"11", name: "小华", pid:"04", job: "后端工程师"},
                  {id:"12", name: "小李", pid:"04", job: "后端工程师"},
                  {id:"13", name: "小赵", pid:"05", job: "测试工程师"},
                  {id:"14", name: "小强", pid:"05", job: "测试工程师"},
                  {id:"15", name: "小涛", pid:"06", job: "运维工程师"}
              ]  
    function h(data) {
        // 空数组
        let result = [];
        // 判断不是数组  直接返回
        if (!Array.isArray(data)) {
            return result
        }
        // 遍历原数组把每一项的children删除掉,因为后面需要增加
        data.forEach(item => {
            delete item.children;
        });
        //  空对象
        let map = {};
       // 遍历原数组,map对象的 键: 是每一项的id  值:每一项
        data.forEach(item =>map[item.id] = item)
        
        data.forEach(item => {
            // item.pid 为0时 返回underfined
            let parent = map[item.pid];
            if (parent) {
                (parent.children || (parent.children = [])).push(item);
            } else {
                // 这里push的item是pid为0的数据
                result.push(item);
            }
        });
        return result;
    }
    console.log(h(data))

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ling…

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值