polyak-888
@polyak-888
Js, React.js, css, frontend

Как работает normalizr?

{
  "id": "123",
  "author": {
    "id": "1",
    "name": "Paul"
  },
  "title": "My awesome blog post",
  "comments": [
    {
      "id": "324",
      "commenter": {
        "id": "2",
        "name": "Nicole"
      }
    }
  ]
}


import { normalize, schema } from 'normalizr';

// Define a users schema
const user = new schema.Entity('users');

// Define your comments schema
const comment = new schema.Entity('comments', {
  commenter: user
});

// Define your article
const article = new schema.Entity('articles', {
  author: user,
  comments: [comment]
});

const normalizedData = normalize(originalData, article);


Это утилита Normalize. Подскажите как работает логики этой утилиты. Читал оф. доки, но они на английском и логики я так и не понял. Если можно простыми словами как формируется нормализованный объект. Что такое user, почему мы постоянно его используем
  • Вопрос задан
  • 3712 просмотров
Пригласить эксперта
Ответы на вопрос 1
Jukk
@Jukk
уменьшает вложенность объектов

https://habr.com/ru/post/332628/

3. Плоские структуры (flatten store)

Такую структуру легко читать, легко бегать циклом foreach по проектам, рендерить подкомпоненты со списками слоев и так далее. Но предположим, что нужно поменять название страницы с id:1. Внутри некоторого маленького компонента, который отрисовывает страницу, вызывается $store.dispatch(«changePageName»,{id:1,name:«new name»}). Как найти место, где в этой глубоко вложенной структуре лежит нужный page с id:1? Пробегать по всему хранилищу? Не лучшее решение.
Ответ написан
Комментировать
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы