Pages
Предупреждение
Работа со страницами и роутингом очень специфична от проекта к проекту
Поэтому здесь приведены общие сведения по этому слою, адаптируйте под свой фреймворк по необходимости
Описание
Здесь располагаются страницы приложения
- соответствующие конкретному роуту
- при необходимости - сгруппированные общей папкой / родительской страницей
Каждая страница должна иметь максимально простую логику
- вся логика отображения, бизнес правил и прочего - должна реализовываться путем композиции нижележащих слоев (
shared
,entitites
,features
) - при этом взаимодействие между нижележащими слоями - также должно осуществляться чаще всего на странице
- Т.е. если
featureA
влияет наfeatureB
на определенной странице - эта логика должна быть прописана в модели самой странице и только на ней! - Без кода в самих фичах и тем более, кросс-импортов!
- Т.е. если
- вся логика отображения, бизнес правил и прочего - должна реализовываться путем композиции нижележащих слоев (
Структура
└── pages/{slice}
├── index.ts
├── lib.ts
├── model.ts
└── ui.tsx
Примеры
Страница оформления заказа
Реализация бизнес-логики заказа очень зависит от вашего проекта, где-то порой это может регулироваться и процессами. Поэтому здесь приведена лишь одна из имплементаций
pages/**/index.tsx
import { Order } from "features/order";
import { ProductCard } from "entities/product";
import { orderModel } from "entities/order";
import { Layout } from "shared/ui/layout"
export const CartPage = () => {
const order = orderModel.useOrder();
// Очень условная разметка
return (
{/** Используем shared (Layout) */}
<Layout>
<Layout.Main>
...
{/** Используем entities (order.items, ProductCard) */}
{order.items.map((item) => (
<ProductCard key={item.id} data={item} />
))}
</Layout.Main>
<Layout.Sidebar>
...
{/** Используем features (Order.TotalInfo) */}
<Order.TotalInfo />
</Layout.Sidebar>
</Layout>
)
}
Страница была полезной?
Ваш фидбек помогает нам улучшать документацию