摇曳的蔷薇
我在这个jsbin示例中使用了lodash和普通JavaScript数组方法的组合:var arr = [3,4,5,5,5,6,8,3,12,1,1,1];var sorted = _.sortBy(_.toPairs(arr.reduce(function(agg, curr) {
agg[curr] = agg[curr] ? agg[curr] + 1 : 1;
return agg;}, {})), function(pair) {
return -pair[1];}).map(function(pair) {
return pair[0];});console.log(sorted); // => ["1", "5", "3", "4", "6", "8", "12"]但是,排序顺序"5"和顺序"1"不同3,4,6,8,12,因为没有为具有相同计数的数字指定排序顺序。上面所做的是创建number=>count(例如{ "1": 3, "5": 3 })的映射,然后将它们配对为元组(因为对象不能在JavaScript中确定性地排序:) [["1", 3], ["5", 3]]。然后,我们简单地根据计数对元组集合进行排序,并映射元组集合以仅返回数字(例如["1", "5", /* etc. */ ])。
肥皂起泡泡
var array = [3, 4, 5, 5, 5, 6, 8, 3, 12, 1, 1, 1];var obj = {};array.forEach(e => obj[e] = obj[e] + 1 || 1);var sorted = Object.keys(obj)
.map(e => ({ n: e, times: obj[e] }))
.sort((a, b) => b.times - a.times)
.map(e => e.n);document.write(sorted);