как добавлять элементы в json при работе с массивами и объектами

Аватар пользователя Ivan Gagarinov
Ivan Gagarinov
22 декабря 2024

Если вам нужно добавить элемент в массив в объекте JSON, можно использовать метод push() в JavaScript.

Пример:

const jsonData = {
  "name": "Ivan",
  "hobbies": ["reading", "gaming"]
};

// Добавим элемент "cooking" в массив "hobbies"
jsonData.hobbies.push("cooking");

// Подсмотрим результат
console.log(JSON.stringify(jsonData, null, 2));

Вывод будет таким:

{
  "name": "Ivan",
  "hobbies": [
    "reading",
    "gaming",
    "cooking"
  ]
}

Чтобы добавить новое свойство в объект JSON, просто назначьте новое значение для нового ключа:

Пример:

const jsonData = {
  "name": "Ivan",
  "age": 30
};

// Добавим новое свойство "gender"
jsonData.gender = "male";

// Подсмотрим результат
console.log(JSON.stringify(jsonData, null, 2));

Вывод будет таким:

{
  "name": "Ivan",
  "age": 30,
  "gender": "male"
}

Если необходимо добавить элемент в вложенный объект или массив, необходимо последовательно обращаться к нужному объекту.

Пример:

const jsonData = {
  "name": "Ivan",
  "address": {
    "city": "Moscow",
    "zip": "101000"
  }
};

// Изменим значение "city" на "Saint Petersburg"
jsonData.address.city = "Saint Petersburg";

// Подсмотрим результат
console.log(JSON.stringify(jsonData, null, 2));

Вывод будет таким:

{
  "name": "Ivan",
  "address": {
    "city": "Saint Petersburg",
    "zip": "101000"
  }
}

Если необходимо добавить новый объект в массив:

Пример:

const jsonData = {
  "name": "Ivan",
  "hobbies": ["reading", "gaming"]
};

// Добавим объект с навыками в массив у jsonData
jsonData.skills = [];
jsonData.skills.push({
  "skill": "programming",
  "level": "advanced"
});

// Подсмотрим результат
console.log(JSON.stringify(jsonData, null, 2));

Вывод будет таким:

{
  "name": "Ivan",
  "hobbies": [
    "reading",
    "gaming"
  ],
  "skills": [
    {
      "skill": "programming",
      "level": "advanced"
    }
  ]
}
0 0
Познакомьтесь с основами JavaScript бесплатно

Есть что добавить? Зарегистрируйтесь

или войдите в аккаунт

Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»

Курсы по программированию в Хекслете

Программирование

Веб-разработка

Разработка, верстка и деплой сайтов и веб-приложений, трудоустройство для разработчиков

Frontend-разработка

Разработка внешнего интерфейса сайтов и веб-приложений и верстка

Создание сайтов

Разработка сайтов и веб-приложений на JS, Python, Java, PHP и Ruby on Rails

Backend-разработка

Разработка серверной части сайтов и веб-приложений

Тестирование

Ручное тестирование и автоматизированное тестирование на JS, Python, Java и PHP

Аналитика данных

Сбор, анализ и интерпретация данных на Python

Интенсивные курсы

Интенсивное обучение для продолжающих

DevOps

Автоматизация настройки локального окружения и серверов, развертывания и деплоя

Математика для программистов

Обучение разделам математики, которые будут полезны при изучении программирования

JavaScript

Разработка сайтов и веб-приложений и автоматизированное тестирование на JS

Тест-драйв

Python

Веб-разработка, автоматическое тестирование и аналитика данных на Python

Java

Веб-разработка и автоматическое тестирование на Java

PHP

Веб-разработка и автоматическое тестирование на PHP

Ruby

Разработка сайтов и веб-приложений на Ruby on Rails

Go

Курсы по веб-разработке на языке Go

Верстка

HTML

Современная верстка с помощью HTML и CSS

SQL

Проектирование базы данных, выполнение SQL-запросов и изучение реляционных СУБД

Git

Система управления версиями Git, регулярные выражения и основы командой строки

Бесплатные курсы

Бесплатные курсы по тестированию, дата-аналитике, верстке, программированию на Python, Java, PHP и JavaScript.

Базы данных

Фреймворки