Динамически добавляют значения и сортировать объект JavaScript
-
27-09-2019 - |
Вопрос
Позвольте сказать, что у меня есть этот массив директоров кино:
var directors = ['Woody Allen', 'Woody Allen', 'Clint Eastwood', 'Quentin Tarantino', 'Robert Rodriguez', 'Woody Allen', 'Steven Soderberg', 'Robert Rodriguez, Quentin Tarantino' ];
PHP Print_r aray будет выглядеть так:
Array
(
[0] => Woody Allen
[1] => Woody Allen
[2] => Clint Eastwood
[3] => Quentin Tarantino
[4] => Robert Rodriguez
[5] => Woody Allen
[6] => Steven Soderberg
[7] => Robert Rodriguez, Quentin Tarantino
)
То, что я хотел бы сделать с ним, заключается в том, - это цикл через массив и создать новый ассоциативный массив с именем в качестве ключа и количество раз, когда он появляется в массиве в качестве значения. PLUS Сортировать массив после наивысшего значения, чтобы конечный результат был бы похожим на Tihs:
Array
(
[Woody Allen] => 3
[Robert Rodriguez] => 2
[Quentin Tarantino] => 2
[Steven Soderberg] => 1
[Clint Eastwood] => 1
)
Я не эксперт на JavaScript, но если бы я сделаю это в PHP, я бы поделаю это:
$directors = array();
foreach($dirs as $d){
$pos = strpos($d,",");
if($pos === false) {
if($directors[$d]){
$directors[$d] = $directors[$d]+1;
}else{
$directors[$d] = 1;
}
}else{
$da = explode(",",$d);
foreach($da as $d){
$d = trim($d);
if($directors[$d]){
$directors[$d] = $directors[$d]+1;
}else{
$directors[$d] = 1;
}
}
}
}
arsort($directors);
Пробовал много способов сделать то же самое в JavaScript, но поскольку ассоциативные массивы не существуют так же в JS, у меня были проблемы сома, чтобы получить его на работу. Мой лучший попыток был этот код, но это не делает то, что я хочу:
function add2array(a,v){
if(a[v] != null){
a[v] = a[v]+1;
}else{
a[v] = 1;
}
}
$.each(directors, function(k, v){
if(v.indexOf(",") != -1){
dirs = v.split(",");
$.each(dirs, function(k, v){
dtrim = $.trim(v);
console.log(dtrim);
add2array(r,dtrim);
});
}else{
add2array(r,v);
}
});
Это делает один большой объект JS с директором в качестве ключа и подсчитывать ценность, но их способ для меня отсортировать это? Или мне нужно сделать массив объектов для этого. Было бы действительно полезным, если кто-то может помочь мне решить это. Я использую jQuery, как вы можете посмотреть, поэтому ваше решение может использовать это.
Решение 2
Я решил это сам:
var r = {}, re = [];
function add2array(a,v){
if(a[v] != null){
a[v] = a[v]+1;
}else{
a[v] = 1;
}
}
$.each(directors, function(k, v){
if(v.indexOf(",") != -1){
dirs = v.split(",");
$.each(dirs, function(k, v){
dtrim = $.trim(v);
add2array(r,dtrim);
});
}else{
add2array(r,v);
}
});
for (var i in r) {
re.push({ name : i, count : r[i] });
}
function compare(a,b) {
if (a.count > b.count)
return -1;
if (a.count < b.count)
return 1;
return 0;
}
re.sort(compare);
Он отлично работает на автономной странице, но должен быть какой-то конфликт с моими другими сценариями, потому что я не могу использовать его, где мне это нужно ...
Другие советы
У ассоциативных массивов нет заказа, поэтому вы не можете их отсортировать. Вам придется сделать массив, содержащий клавишу: Value Pairs, а затем сортировать на свойство элемента.