-
Notifications
You must be signed in to change notification settings - Fork 16
Array.prototype.sort
entries()
every()
filter()
find()
findIndex()
flatMap()
forEach()
keys()
map()
reduce()
reduceRight()
some()
В полном смысле слова этот метод нельзя назвать методом итерирования массива, поскольку число итераций больше чем число элементов массива
Однако итерации имеют место быть
И перебор элементов массива налицо
Метод сортирует массив согласно заданному условию сортировки
Условие сортировки проверяет передаваемая методу функция
Функция получает два аргумента для попарного сравнения
Функция возвращает одно из трех значений:
- 0 - совпадение элементов
- 1 - первый аргумент больше второго
- -1 - второй аргумент больше первого
На основании возвращенного функцией значения метод меняет порядок следования элементов в массиве
var sourceArray = [
{ title: "fond", value: 100 },
{ title: "salary", value: 400 },
{ title: "bonus", value: 70 },
{ title: "debt", value: 700 },
{ title: "credit", value: 200 },
{ title: "payments", value: 150 },
{ title: "income", value: 320 },
]
var resArray = sourceArray.sort (
function ( x, y ) {
return x.value - y.value
}
)▼ (7) [{…}, {…}, {…}, {…}, {…}, {…}, {…}]
► 0: {title: "bonus", value: 70}
► 1: {title: "fond", value: 100}
► 2: {title: "payments", value: 150}
► 3: {title: "credit", value: 200}
► 4: {title: "income", value: 320}
► 5: {title: "salary", value: 400}
► 6: {title: "debt", value: 700}
length: 7
► __proto__: Array(0)Для понимания механизма сортировки выведем в консоль значения сравниваемых элементов массива на каждой итерации:
var resArray = sourceArray
.sort (
function ( x, y ) {
console.log ( `${x.title} - ${y.title} = ${x.value - y.value}` )
return x.value - y.value
}
)fond - bonus = 30
payments - fond = 50
credit - payments = 50
income - credit = 120
salary - income = 80
debt - salary = 300или так:
var tmp =[]
var resArray = sourceArray
.sort (
function ( x, y ) {
tmp.push ( {
id: x.title + " > " + y.title,
res: x.value > y.value
} )
return x.value - y.value
}
)▼ (13) [...]
► 0: "salary - fond = 300"
► 1: "bonus - salary = -330"
► 2: "bonus - salary = -330"
► 3: "bonus - fond = -30"
► 4: "debt - fond = 600"
► 5: "debt - salary = 300"
► 6: "credit - salary = -200"
► 7: "credit - fond = 100"
► 8: "payments - credit = -50"
► 9: "payments - fond = 50"
► 10: "income - credit = 120"
► 11: "income - debt = -380"
► 12: "income - salary = -80"
length: 13
► __proto__: Array(0)Итак, в отличие от других итерирующих методов, функция, передаваемая методу в качестве единственного аргумента, принимает строго два параметра
☝ Самостоятельно попробуйте нарисовать блок-схему алгоритма сортировки массива методом sort()
© Irina H.Fylyppova 2018
Использование данных материалов или любой их части коммерческими школами ( курсами ) является нарушением авторских прав
| 1 | 2 | 3 | 4 | 5 |
| 6 | 7 | 8 | 9 | 10 |
| 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 |
| ⏬ |
|---|
- Блок-схема алгоритма
- Developer Tools
- Chrome DevTools
- Переменные
- Оператор typeof
- Структуры данных
- Операторы присваивания
- Логические выражения
- Условные операторы
- Инкремент
- Свойство length
- Оператор цикла for
- UTF-8
Homework
- Приведение типов
- NaN | null | Infinity
- BigInt (ES10)
- Функции
- Методы
- Методы строк
- Методы массивов
- Date ()
Самостоятельная работа
Практика (XSS)
Homework
- Циклы while и do...while
- Циклы for...of и for...in
- Параметры по умолчанию
- Объект function
Практика
Homework
- Нативные и host-объекты
- Литерал объекта
- Унаследованные свойства
- Конструктор
- Модель наследования
- Публичные и приватные свойства
- Оператор in
1
Homework
- Итерирующие методы массивов
- Тестирование производительности
- SHA
Homework
- Размеры и прокрутка элемента
- Event Loop
- async | await
- API
- REST | HATEOAS
- status codes
JSON placeholder-
JSON server
fake chat
Homework
- strict mode
- Вычисляемые имена свойств
- Краткий синтаксис методов
- Краткий литерал объекта
- Классы
Homework
- :not(:defined)
- Shadow DOM
- Custom elements
- Lifecycle hooks
- whenDefined
- <template>
- slot
1
2
3
Homework
- npm
- webpack
Упражнение 1- ES6 модули
Упражнение 2- --mode | --watch
Упражнение 3
Упражнение 4
Упражнение 5
Упражнение 6
Упражнение 7
Упражнение 8
Homework
| ⏫ |
|---|

Дополнительно
Справочная инфо
Git Bush
TCP/IP
Коды символов