Как поменять местами значение объекта по набору индекса в javascript

У меня есть такой массив

arrayValue=[
    { value: 1}, 
    { value: 2}, 
    { value: "line break"}, 
    { value: 3}, 
    { value: 4}, 
    { value: "line break"}, 
    { value: 1}, 
    { value: 1}
]

Мне нужно поменять местами вперед или назад значение на 2 набора индексов, каждый 3 индекса значения имеет стрелку вверх и вниз, когда я нажимаю стрелку вверх / вниз, необходимо поменять местами на основе этих двух индексов вперед или назад. Например 0-й, 3-й, 6-я стрелка. кто-нибудь поможет этому?

Не очень понятно, что вам нужно.

basic 14.09.2018 19:13

Ват ????????

Damian Czapiewski 14.09.2018 19:13

Трудно понять ваш сценарий и проблему.

Abhinav Kumar 14.09.2018 19:14

Я не знаю, как объяснить свою проблему. Бывший. Если мне нужно поменять местами первые два элемента, значит, мне нужен результат arrayValue = [{value: 3}, {value: 4}, {value: "line break"}, {value: 1}, {value: 2}, {value : "разрыв строки"}, {значение: 1}, {значение: 1}] @DamianCzapiewski

Ravi Kumar Gopalakrishnan 14.09.2018 19:16

@RaviKumarGopalakrishnan, проверьте мой ответ, но я не знаю, хотите ли вы это сделать.

Damian Czapiewski 14.09.2018 19:34
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
5
61
1

Ответы 1

Если я вас правильно понял, это будет примерно так, как показано ниже.

function _move(arr, idx, dir) {
    var res = arr.slice();
    var thrown = res.splice(idx, 1)[0];
    if (dir === 'up') {
        res.splice(idx-1, 0, thrown);
    } else {
        res.splice(idx+1, 0, thrown);
    }
    return res;
} 

Array.prototype.up = function (idx) {
    return _move(this, idx, 'up');
};

Array.prototype.down = function (idx) {
    return _move(this, idx, 'down');
};

var a = [1, 2, 3, 4, 5];
console.info(
    a.up(2), // 1 3 2 4 5
    a.down(2) // 1 2 4 3 5
);

ОБНОВИТЬ

Если вы хотите поменять местами элементы n, левые, начиная с L, а правые, начиная с R, - позвоните в swapItems(arr, L, R, n). Вот реализация, которую я написал:

function swapItems(arr, leftIdx, rightIdx, itemsNum) {
    var leftOnes = arr.splice(leftIdx, itemsNum);
    var rightOnes = arr.splice(rightIdx - itemsNum, itemsNum);
    arr.splice(leftIdx, 0, ...rightOnes);
    arr.splice(rightIdx, 0, ...leftOnes);
}

var arr = [1, 2, 'br', 3, 4, 'br', 1, 1];

// first pair starts at 0, another pair start at 3, number of items to affect = 2
swapItems(arr, 0, 3, 2);
// arr = [3, 4, 'br', 1, 2, 'br', 1, 1]

Другие вопросы по теме