169 похожих чатов

Если кто-то работал с Zustand и Nextjs, можете пожалуйста объянить,

для чего делается вот такая обертка с конекстом вокруг всех страниц?
https://github.com/vercel/next.js/blob/canary/examples/with-zustand/lib/zustandProvider.js
https://github.com/vercel/next.js/blob/canary/examples/with-zustand/pages/_app.js

7 ответов

9 просмотров

чтобы стор был доступен во всех дочерних компонентах

Потому что Zustand это стейт-менеджер, наподобие redux. Поэтому контекст используется для общего стора во всём приложении

Radik-Khammatov Автор вопроса

Вчера задавал вопрос по поводу Zustan стейт менеджера, мне ответили, что провайдер нужен, чтобы каждый компонент мог получить доступ к стору. Но сейчас методом пробы я выяснил, что никакой провайдер для корректной работы не нужен, стейт менеджер работает и без него. Это написано и в их документации. Потому вопрос снова актуален. Буду очень благодарен, если кто-то поможет разобраться.

Radik Khammatov
Вчера задавал вопрос по поводу Zustan стейт менедж...

Я быстренько пробежался по документации и не увидел поддержки SSR. Полагаю, в контекст обернули, чтобы расшарить state для SSR.

Radik Khammatov
Вчера задавал вопрос по поводу Zustan стейт менедж...

Проблема в чем (если я не ошибаюсь)? Когда ты запускаешь nodejs-сервер и выполняешь на нем рендеринг, то любые изменения с твоим стором будут записаны в памяти. И когда следующий человек сделает запрос, то он эти изменения тоже получит (хотя должен был получить неизмененный вариант). А контекст решает эту проблему, поскольку он неизменяем (если не ошибаюсь) и возвращает каждый раз чистое состояние для каждого запроса.

Radik-Khammatov Автор вопроса
Radik Khammatov
Спасибо большое, буду разбираться

почитай вот issue, может станет понятней что-нибудь https://github.com/pmndrs/zustand/issues/182

Похожие вопросы

Обсуждают сегодня

Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
А чем вам питонисты не угодили?😂
.
79
Можно ли загрузить скрипт py в бота чтобы он работал по нему? как это сделать?
huskadam #RCC Фанат? @hitlerpvp
13
Всем здравствуйте! Я хотел узнать сколько стоит средняя месячная зарплата у Electron js разработчиков? Мне очень это важно и нужно, плиз помогите узнать эту инфу! Для Джунио...
U.K.
10
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
83
А дин типизация это хорошо или плохо?
Alexey
12
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Hello. Could you please help me with finding all coordinates within a radius using a spatial index, given that I have a table with coordinates? SET @lng = 37.57925; SET @lat ...
Rinchin G
8
Карта сайта