构造按字母顺序排列的对象数组

时间:2016-01-11 20:02:50

标签: javascript arrays angularjs

我有一个名为property ...

的对象数组
var myList = [{
  name: 'Apple'
}, {
  name: 'Nervousness',
}, {
  name: 'Dry'
}, {
  name: 'Assign'
}, {
  name: 'Date'
}]

基本上,我正在尝试创建一个这样的数组:

[{
  name: 'A',
  items: [{
    name: 'Apple'
  }, {
    name: 'Assign'
  }]
}, {
  name: 'D',
  items: [{
    name: 'Date',
  }, {
    name: 'Dry',
  }]
}, {
  name: 'N',
  items: [{
    name: 'Nervousness',
  }]
}];

基本上,我的对象数组需要按字母顺序排列,放入一个新对象,其父键/值为'name',并带有相应的字母。

我可以将它们按字母顺序排列如下......

myList.sort(function (a, b) {
  if (a.name < b.name) return -1;
  if (a.name > b.name) return 1;
  return 0;
});

然后我可以创建第一个字母的数组......

var headerLetters = [];
angular.forEach(myList, function (item) {
  var firstLetter = item.name.charAt(0);
  if (headerLetters.indexOf(firstLetter) === -1) {
    headerLetters.push(firstLetter);
  }
});

但是这就是我被卡住的地方......我可以检查重复的第一个字母,但是我如何迭代我的对象列表并按字母顺序将它们推入一个新的对象数组?

1 个答案:

答案 0 :(得分:2)

假设您先按字母顺序对它们进行排序,那么您可以随时检查数组中的最新项目,看它是否与当前名称匹配。

var headerLetters = [];
angular.forEach(myList, function(item) {
  var firstLetter = item.name[0];
  var lastObj = headerLetters[headerLetters.length - 1];
  if (!lastObj || lastObj.name !== firstLetter) {
    lastObj = {
      name: firstLetter,
      items: []
    };
    headerLetters.push(lastObj);
  }
  lastObj.items.push(item);
});