为了账号安全,请及时绑定邮箱和手机立即绑定

对具有 Object 数组的 JavaScript 数组进行排序

对具有 Object 数组的 JavaScript 数组进行排序

撒科打诨 2022-05-26 15:39:18
您能否建议我根据部分名称按优先级对以下数组进行排序的最佳方法。我更担心时间复杂度,因为我的数组实际上包含 100 000 条记录。如果有更好的存储方式,我也可以更改数组结构[{    id: 'field1',    sections: [{        name: 'Top_Section',        priority: 3      },      {        name: 'Bottom_Section',        priority: 3      }    ]  },  {    id: 'field2',    sections: [{        name: 'Top_Section',        priority: 2      },      {        name: 'Bottom_Section',        priority: 4      }    ]  },  {    id: 'field3',    sections: [{        name: 'Top_Section',        priority: 1      },      {        name: 'Bottom_Section',        priority: 1      }    ]  },  {    id: 'field4',    sections: [{        name: 'Top_Section',        priority: 4      },      {        name: 'Bottom_Section',        priority: 2      }    ]  }];就像我想根据 Top_Section 对优先级进行排序一样,所以我的预期输出应该如下所示,因为 field3 的优先级为 1,而 field2 的优先级为 2,依此类推。[  {    id: 'field3',    sections: [      { name: 'Top_Section', priority: 1 },      { name: 'Bottom_Section', priority: 1 }    ]  },  {    id: 'field2',    sections: [      { name: 'Top_Section', priority: 2 },      { name: 'Bottom_Section', priority: 4 }    ]  },  {    id: 'field1',    sections: [      { name: 'Top_Section', priority: 3 },      { name: 'Bottom_Section', priority: 3 }    ]  },  {    id: 'field4',    sections: [      { name: 'Top_Section', priority: 4 },      { name: 'Bottom_Section', priority: 2 }    ]  }];
查看完整描述

2 回答

?
幕布斯6054654

TA贡献1876条经验 获得超7个赞

我在这里假设“Top_Section”总是在sections 数组的第一个位置。


我还假设只有两种优先级类型:“Top_Section”和“Bottom_Section”


let list = [{

    id: 'field1',

    sections: [{

        name: 'Top_Section',

        priority: 3

      },

      {

        name: 'Bottom_Section',

        priority: 3

      }

    ]

  },

  {

    id: 'field2',

    sections: [{

        name: 'Top_Section',

        priority: 2

      },

      {

        name: 'Bottom_Section',

        priority: 4

      }

    ]

  },

  {

    id: 'field3',

    sections: [{

        name: 'Top_Section',

        priority: 1

      },

      {

        name: 'Bottom_Section',

        priority: 1

      }

    ]

  },

  {

    id: 'field4',

    sections: [{

        name: 'Top_Section',

        priority: 4

      },

      {

        name: 'Bottom_Section',

        priority: 2

      }

    ]

  }

];


function sortBy(priorityName) {

  let priorityPosition = (priorityName == 'Top_Section') ? 0 : 1;

  

  return (a, b) => {

    return a['sections'][priorityPosition].priority - b['sections'][priorityPosition].priority;

  }

}


console.log( list.sort(sortBy('Top_Section')) );


查看完整回答
反对 回复 2022-05-26
?
潇潇雨雨

TA贡献1833条经验 获得超4个赞

让我们创建一个比较器


function compare(a, b) {

    var sumA = 0;

    var sumB = 0;

    for (var section of a.sections) sumA += section.priority;

    for (var section of b.sections) sumB += seciton.priority;

    return sumB - sumA;

}


arr.sort(compare);

如果第一个参数较大,比较器返回正数,如果第二个参数较大,则比较器返回负数,如果它们相等,则返回 0。我假设优先级总和的数值越小,项目越大。


查看完整回答
反对 回复 2022-05-26
  • 2 回答
  • 0 关注
  • 195 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信