Вход

Просмотр полной версии : Обобщенная функция сортировки массива


Marson
07.11.2018, 23:37
Сделайте обобщенную функцию сортировки массива


var persons = [
{name: "Иван", age: 17},
{name: "Мария", age: 35},
{name: "Алексей", age: 73},
{name: "Яков", age: 12},
]

sort(persons, "age"); //сортирует по возрасту по возрастанию
sort(persons, "name", false); //сортирует по имени по убыванию
Функция позволяет отсортировать любой набор данных по имени поля (второй параметр). Третьим параметром идет необязательный Boolean, который в случае true делает сортировку по возрастанию, в случае false - по убыванию. По умолчанию (без третьего параметра) происходит сортировка по возрастанию.

function byField (field) {
return function (a, b) {
return a[field] > b[field] ? 1 : -1;
};
}
var users = [{
name: "Вася",
surname: 'Иванов',
age: 20
}, {
name: "Петя",
surname: 'Чапаев',
age: 25
}, {
name: "Маша",
surname: 'Медведева',
age: 18
}];
byField();

users.sort(byField('age'));
users.forEach(function(user) {
console.log( user.age);
});


Подскажите, здесь можно без метода sort() сделать?

рони
07.11.2018, 23:56
здесь можно без метода sort() сделать?
можно но зачем? и функция byField должна вернуть и ноль тоже.

Пожалуйста, отформатируйте свой код!

Для этого его можно заключить в специальные теги: js/css/html и т.п., например:


... ваш код...



О том, как вставить в сообщение исполняемый javascript и html-код, а также о дополнительных возможностях форматирования - читайте http://javascript.ru/formatting.

рони
08.11.2018, 00:11
Marson,
Сортировка пузырьком, JavaScript (https://medium.com/@alivander/сортировка-пузырьком-javascript-54462b2989a6)

Marson
08.11.2018, 11:53
function byField (field) {
return function (a, b) {
return a[field] > b[field] ? 1 : -1;
};
}
var users = [{
name: "Вася",
surname: 'Иванов',
age: 20
}, {
name: "Петя",
surname: 'Чапаев',
age: 25
}, {
name: "Маша",
surname: 'Медведева',
age: 18
}];
byField();

users.sort(byField('age'));
users.forEach(function(user) {
console.log( user.age);
});

рони
08.11.2018, 14:02
Marson,
спасибо Malleys, взято тут
https://javascript.ru/forum/misc/75800-funkciya-dlya-sortirovki-tablicy.html#post498107
<script>
function byField(field, order) {
var collator = new Intl.Collator(["en", "ru"], {
numeric: true
});
order = order ? 1 : -1;
return function(a, b) {
return order * collator.compare(a[field], b[field])
};
}
var users = [{
name: "Вася",
surname: 'Иванов',
age: 20
}, {
name: "Петя",
surname: 'Чапаев',
age: 25
}, {
name: "Маша",
surname: 'Медведева',
age: 18
}];

users.sort(byField('age', true));
users.forEach(function(user) {
console.log(user.age);
});

</script>

Marson
08.11.2018, 21:53
Спасибо вам!