Аватар для UseMuse
154 / 154 / 60
Регистрация: 11.01.2016
Сообщений: 1,325

Глубокое клонирование объекта без promise и async

06.06.2019, 14:21. Показов 1864. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как создать клона этого объекта без promise и async?
Чтобы редактирование array не влияло на копию
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
let array = [
  {
    name : 'Jon', parentName : null, 
    children : [{
                name : 'OLIVIA', parentName : 'Alex',
                children : [{name : 'THOMAS', parentName : 'OLIVIA'}]
              }]
   },
   {
     name : 'NOAH', parentName : null, 
     children : [{
                  name : 'CHLOE', parentName : 'NOAH', 
                  children: [{name : 'LEO', parentName : 'CHLOE'}]
               }]
   },
   {
     name : 'Alex', parentName : null
   },
  {
     name : 'ALFIE', parentName : 'Alex', 
     children : [{
                  name : 'HARRY', parentName : 'ALFIE', 
                  children: [{name : 'JAKE', parentName : 'Alex'}]
               }]
   },]
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.06.2019, 14:21
Ответы с готовыми решениями:

Глубокое клонирование объектов не работает
Всем привет. Я на этапе обучения, дошел вот до темы с объектами, увидел пример с клонированием, и решил написать небольшой код, который бы...

Клонирование объекта и помещение его на страницу с сохранением координат
Здравствуйте, кто нибудь будьте добры помогите решить следующую задачу: как обычную картинку определённого размера, помещать в любое место...

Клонирование элемента с событиями без использования JQuery
Как клонировать элемент вместе с его событиями? Например в этом примере https://jsfiddle.net/mx74j85d/2/ при нажатии на круг он...

4
Эксперт JS
2037 / 1096 / 409
Регистрация: 29.04.2016
Сообщений: 2,625
06.06.2019, 15:40
Лучший ответ Сообщение было отмечено UseMuse как решение

Решение

UseMuse,

https://codepen.io/Mr_Sergo/pe... itors=0010
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
let array = [
    {
        name : 'Jon', parentName : null,
        children : [{
            name : 'OLIVIA', parentName : 'Alex',
            children : [{
                name : 'THOMAS', parentName : 'OLIVIA'
            }]
        }]
    },
    {
        name : 'NOAH', parentName : null, 
        children : [{
            name : 'CHLOE', parentName : 'NOAH', 
            children: [{
                name : 'LEO', parentName : 'CHLOE'
            }]
        }]
    },
    {
        name : 'Alex', parentName : null
    },
    {
        name : 'ALFIE', parentName : 'Alex', 
        children : [{
            name : 'HARRY', parentName : 'ALFIE', 
            children: [{
                name : 'JAKE', parentName : 'Alex'
            }]
        }]
},];
 
let copy = JSON.parse(JSON.stringify(array));
 
array[0].name = 'NOT Jon';
array[1].children[0].children[0].parentName = 'NOT CHLOE';
 
alert(
    array[0].name + '\n' + 
    copy[0].name + '\n' + 
    array[1].children[0].children[0].parentName + '\n' + 
    copy[1].children[0].children[0].parentName
);
2
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
06.06.2019, 18:55
Mr_Sergo, здравствуй))
slice же
JavaScript
1
array.slice();
0
Эксперт JS
2037 / 1096 / 409
Регистрация: 29.04.2016
Сообщений: 2,625
06.06.2019, 19:56
Приветствую
Цитата Сообщение от Qwerty_Wasd Посмотреть сообщение
slice же
нет же

https://codepen.io/Mr_Sergo/pe... itors=0010
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
let array = [
    {
        name : 'Jon', parentName : null,
        children : [{
            name : 'OLIVIA', parentName : 'Alex',
            children : [{
                name : 'THOMAS', parentName : 'OLIVIA'
            }]
        }]
    },
    {
        name : 'NOAH', parentName : null, 
        children : [{
            name : 'CHLOE', parentName : 'NOAH', 
            children: [{
                name : 'LEO', parentName : 'CHLOE'
            }]
        }]
    },
    {
        name : 'Alex', parentName : null
    },
    {
        name : 'ALFIE', parentName : 'Alex', 
        children : [{
            name : 'HARRY', parentName : 'ALFIE', 
            children: [{
                name : 'JAKE', parentName : 'Alex'
            }]
        }]
},];
 
let coppy = array.slice();                  // копируем ДО изменения основного массива
 
array[0].name = 'NOT Jon';                  // меняем значение у основного массива
coppy[0].children[0].name = 'NOT OLIVIA';   // меняем значение у копии
 
alert(
    coppy[0].name + '\n' +                  // `NOT Jon` - неправильно, выше поменяли значение в основном массиве а поменялось и в копии
    array[0].name + '\n' +                  // `NOT Jon` - тут все в порядке
    coppy[0].children[0].name + '\n' +      // `NOT OLIVIA` - тут все в порядке
    array[0].children[0].name               // `NOT OLIVIA` - неправильно, выше поменяли значение в копии а поменялось и в основном массиве
);
1
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
06.06.2019, 20:06
Mr_Sergo, точно, забыл совсем про
Цитата Сообщение от UseMuse Посмотреть сообщение
не влияло на копию

Не по теме:

в который раз уже лоханулся на том, что поторопился )))))))))))

1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.06.2019, 20:06
Помогаю со студенческими работами здесь

Клонирование объекта в <form>
Проблемка. Грубо говоря есть вот что: &lt;form&gt; &lt;fieldset&gt; &lt;legend&gt;клон&lt;/legend&gt; &lt;input...

Клонирование объекта с новыми параметрами
Доброго времени суток. Клонирую объект с новыми параметрами. Как это правильно записать? // В обычной записи выглядит так // obj.name...

Глубокое клонирование объекта, содержащий массив объектов
Добрый вечер. Есть перечисление MyEnum и класс с массивом перечислений class A{ MyEnum enum; public GameState clone()...

Что значит глубокое клонирование?
Я понимаю, что такое поверхностное клонирование, но не могу реализовать глубокое, ибо не понимаю, в чем его суть. Вот примеры с...

Клонирование объекта
Здравствуйте, есть класс Student с полем marks (массив) и есть два объекта этого класса studentOne и studentTwo. Объект studentOne...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru