Динамически добавляют значения и сортировать объект JavaScript

StackOverflow https://stackoverflow.com/questions/4064217

Вопрос

Позвольте сказать, что у меня есть этот массив директоров кино:

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, а затем сортировать на свойство элемента.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top