Как создать несвязанную переменную в angular?

Мне нужно получить данные с сервера (или файла json) и добавить их в «firstVariable», чтобы выполнить с ним некоторые манипуляции, и «secondVariable» для неизмененных данных по умолчанию (те же данные с сервера). Но когда я меняю данные в firstVariable, они также меняются и во secondVariable. Мой вопрос: Почему? Когда я добавляю данные в переменные, я создаю из них новый массив. Есть пример

Потому что вы манипулируете одним и тем же типом ссылка. Добавьте console.info(data); и вы увидите, что данные представляют собой массив объектов, передача их в новый массив не меняет того факта, что новый массив будет получать указатели на те же экземпляры.

Igor 12.03.2019 21:52

Возможный дубликат Как вы клонируете массив объектов в Javascript?

Igor 12.03.2019 21:55
Поведение ключевого слова "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
3
41
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Проблема заключается в том, что когда вы используете оператор распространения [...data], вы распространяете ссылку на объекты внутри массива.

Вместо этого вы хотите сопоставить объекты с новой ссылкой на объект, вы можете сделать что-то вроде

this.json = data.map(x => Object.assign({}, x));

См. следующий фрагмент.

let data = [{ id: 123 }];

let a = [...data];
let b = [...data];

a[0].id= 1234;

console.info('Without creating a new object');
data = [{ id: 123 }];
console.info(`A: ${JSON.stringify(a)}`);
console.info(`B: ${JSON.stringify(b)}`);


let c = data.map(x => Object.assign({}, x));
let d = data.map(x => Object.assign({}, x));

c[0].id= 9999;

console.info('Creating a new object');
console.info(`C: ${JSON.stringify(c)}`);
console.info(`D: ${JSON.stringify(d)}`);

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