javascript数组对象排序问题

发布于 2022-09-12 23:07:48 字数 2494 浏览 17 评论 0

现在有arr1arr2两个数组,以arr1字段顺序为准,对arr2进行排序更新value值

let arr1 = [
    {
        title:"姓名",
        property:"name",
        width:120
    },
    {
        title:"年龄",
        property:"age", 
        width:120
    },
    {
        title:"角色",
        property:"role",
        width:120
    },
    {
        title:"修改前",
        property:"modify",
        width:120
        children:[
            {
                title:"体重",
                property:"weight",
                width:120
            },
            {
                title:"身高",
                property:"tall",
                width:120
            }
        ]
    }
]
let arr2 = [
   {
        title:"年龄",
        property:"age",
        width:100,
        date:()=>{},
        visible:false,
        id:2
    },
    {
        title:"修改前",
        property:"modify",
        width:100,
        children:[
            {
                title:"身高",
                property:"tall",
                width:100,
                visible:true,
                id:5
            },
            {
                title:"体重",
                property:"weight",
                width:100,
                visible:true,
                id:6
            }
        ]
    },
    {
        title:"姓名",
        property:"name",
        width:100,
        visible:false,
        id:3
    },
    {
        title:"角色",
        property:"role",
        width:100,
        visible:true,
        id:1
    }
]

想要如下效果

let arr3 = [
    {
        title:"姓名",
        property:"name",
        width:120,
        visible:false,
        id:3
    },
    {
        title:"年龄",
        property:"age",
        width:120,
        visible:false,
        id:2,
        renderWidth: 140,
        date:()=>{}
    },
    {
        title:"角色",
        property:"role",
        width:120,
        visible:true,
        id:1
    },
    {
        title:"修改前",
        property:"modify",
        width:120,
        children:[
            {
                title:"体重",
                property:"weight",
                width:120,
                visible:true,
                id:6
            },
            {
                title:"身高",
                property:"tall",
                width:120,
                visible:true,
                id:5
            }
        ]
    }
]

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

紫竹語嫣☆ 2022-09-19 23:07:48

这是我试验后的结果


const childOrderMap = new Map();

// 获取到顺序以及 children 的顺序
function getOrder (arr, key) {
  return arr.map(item => {
    if (item.children) {
      childOrderMap.set(item[key], getOrder(item.children, key));
    }
    return item[key];
  });
};

const order = getOrder(arr1, 'property');

function mapOrder(array, order, key) {
  return array.sort((a, b) => {
    const itemA = a[key];
    const itemB = b[key];
    // 对 children 进行排序
    if (a.children) {
      const childOrder = childOrderMap.get(itemA);
      a.children = mapOrder(a.children, childOrder, key);
    }
    if (b.children) {
      const childOrder = childOrderMap.get(itemB);
      b.children = mapOrder(b.children, childOrder, key);
    }
    return order.indexOf(itemA) - order.indexOf(itemB);
  })
}

const result = mapOrder(arr2, order, 'property');
console.log(result);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文