@YanaLins
web

Как добавить поле в объект и вложенные в него объекты?

Есть структура данных: массив объектов с вложенными обектами, у некоторых из них может быть массив вложенных объектов и так далее по вложенности. Нужно добавить к каждому объекту поле disabled, которое зависит от выбранного device_type_id. Пример исходного массива:
[
    {
        "device_type_id": 1,
        "children": [
            {
                "name": "MacOS",
                "id": 4,
                "children": [
                    {
                        "name": "OS X 10",
                        "id": 35
                    }
                ]
            },
            {
                "name": "Windows",
                "id": 3,
                "children": [
                    {
                        "name": "Windows XP",
                        "id": 28,
                        "key": "1_28"
                    },
                    {
                        "name": "Windows Vista",
                        "id": 29,
                        "key": "1_29"
                    }
                ],
                "key": "0.09045594089569153-1"
            },
            {
                "name": "Linux",
                "id": 5,
                "key": "1_5"
            },
            {
                "name": "Other",
                "id": 6,
                "key": "1_6"
            }
        ],
        "key": 1
    },
    {
        "device_type_id": 2,
        "children": [
            {
                "name": "Android",
                "id": 1,
                "children": [
                    {
                        "name": "Android 14",
                        "id": 17,
                        "key": "2_17"
                    },
                    {
                        "name": "Other",
                        "id": 18,
                        "key": "2_18"
                    }
                ],
                "key": "0.6381681047050869-0"
            },
            {
                "name": "Other",
                "id": 6,
                "key": "2_6"
            }
        ],
        "key": 2
    }
]


Одна из множества попыток добавить поле:
disabledOs() {
      this.form.os.map(with_device => {
        const isDisabled = !this.form.device_types.includes(
          with_device.device_type_id
        )
        with_device.disabled = isDisabled

        if (!with_device?.children) return
        with_device.children.map(el => {
          el.disabled = isDisabled

          if (!('device_type_id' in el)) {
            'children' in el
              ? el.children.map(child => (child.disabled = isDisabled))
              : (el.disabled = isDisabled)
          }
        })
      })

      return this.form.os
    }
  }


Заранее спасибо за помощь :)
  • Вопрос задан
  • 136 просмотров
Пригласить эксперта
Ответы на вопрос 1
Elaryks
@Elaryks
В вашем методе disabledOs свойство children у элементов не меняется, т. к. метод map не мутирует переданный в него массив, а возвращает новый.

disabledOs() {
    const modifyElement = (el, isDisabled) => {
        return {
            ...el,
            ...(el.children && {
                children: el.children.map(c => modifyElement(c, isDisabled)),
            }),
            disabled: isDisabled,
        };
    };

    return this.form.os.map(el => {
        const isDisabled = !this.form.device_types.includes(el.device_type_id);

        return modifyElement(el, isDisabled);
    });
};
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
SummerWeb Ярославль
от 120 000 до 180 000 ₽
КРАФТТЕК Санкт-Петербург
от 60 000 до 80 000 ₽
Brightdata Тель-Авив
от 5 500 до 6 500 $
16 июн. 2024, в 20:43
90909 руб./за проект
16 июн. 2024, в 19:56
30000 руб./за проект