Skip to content

Latest commit

 

History

History
47 lines (40 loc) · 2.67 KB

README.md

File metadata and controls

47 lines (40 loc) · 2.67 KB

HypeRouter

Как поставить

npm i

Ядро

Что надо знать

Куда смотреть

  • Router/ctx.ts
  • Router/HistoryRouter.tsx
  • Router/Route.tsx
  • Router/Link.tsx

Полезные выводы

  • В реакте принято пользоваться контекстом и колбеками, а не событиями и шинами для них. тогда и код проще
  • Компоненты это не только про отображение
  • Композиция решает
  • По Link.tsx можно понять (условие клика, сквозные пропсы), почему лучше использовать библиотеки и читать код опенсорса, а не велосипедить в слепую (всегда найдутся нюансы)
  • Если разбивать контексты по частоте \ причине обновления можно избежать того, что, например ссылки перерендериваются каждую смену страницы
  • Хуки топ

Продвинутое

Что надо знать

Куда смотреть

  • Router/MemoryRouter.ts
  • Router/AsyncRoute.tsx
  • Router/Redirect.tsx
  • Router/Switch.tsx

Полезные выводы

  • Контекст разделяет провайдера и потребителя, а потому их можно подменять свободно (MemoryRouter.ts)
  • Для решения особых задач отлично заходит кастомный хук (NavLink.ts и Route.tsx)
  • Код сплиттинг в 2019 -- легко (AsyncRoute.tsx, About.tsx, ChunkyPage.tsx) (Slow 3G выключенный после загрузки Home -- ваш лучший друг для того чтобы посмотреть на loading...)
  • Композиция решает (ну вы поняли: AsyncRoute, Redirect)
  • Композицией не надо злоупотреблять (как упражнение перепишите NavLink.ts на использование Route)
  • Хуки топ )))
  • Если вы используете React для конфигурации, React.Children + child.props ваши лучшие друзья (да, в реакте есть только пропсы) (см. Switch.tsx)