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

Привет. Столкнулся в светлките с тем, что стор каким-то образом

сохраняет свой стейт на сервере.
Ситуация:
Ич-блок отрисовывает элементы для массива, который лежит в сторе.
То бишь, в жс файле:

import { writable } from 'svelte/store';
export let array = writable([])

В компоненте:
import { array } from './store.js'
$array.push(el)

{#each $array as el}
<div> {el}</div>
{/each}

При обновлении страницы сначала мигает огромный список, где количество элементов равно числу обновлений страницы. При отработке клиента элемент остается один. Если логировать длину массива, то на сервере и в браузере она отличается (на сервере растет). В куки ничего не пишет.
При отключении/поднятии сервера сбрасывается.
Шаблон свелткита, ничего в нем не менял в общем-то.

Как такое может быть? В саппере такого не было :/

11 ответов

9 просмотров

Стор в ESM модуле — это всегда синглтон. Кит тут не при чём, это не баг и не фича. Это стандартное поведение ESM модулей. Поведение модуля на клиенте и на сервере не будет отличатся — вы всегда будете обращаться к одному и тому же объекту, с одинаковыми данными. Как на клиенте, так и на сервере. На клиенте вы увидите клиентские данные. А на сервере — данные стора, которые были мутированы последним запросом, от любого клиента. Всё потому, что сервер, так же как клиент, один раз импортирует модуль и работает с единым инстансом для любых запросов. В итоге на сервере он будет единым для всех клиентов. Для передачи уникальных данных между компонентами на сервере используйте Stuff. Про Singleton: youtube Про Stuff: youtube @NikitaFedorovv

Misha Rodshtein
Стор в ESM модуле — это всегда синглтон. Кит тут...

Он так долго рассказывал про то как работает Cookie, что я пропустил момент где речь идет о том, как решили проблему синхронизации хранилища с сервером. Сколько не крутил, не смог найти. Может кто то в двух словах пояснить смысл задумки и ее реализацию.

Ivan Ivanovich
Он так долго рассказывал про то как работает Cooki...

Что за «синхронизация хранилища с сервером»?

Misha Rodshtein
Что за «синхронизация хранилища с сервером»?

Как я понял по видео там в момент построения на стороне сервера создается хранилище а на стороне клиента изменяются значения и получается рассинхрон, хотя может я не прав.

Ivan Ivanovich
Как я понял по видео там в момент построения на ст...

Не прав. В видео даже близко этого нет. Видео объясняет как можно выстрелить себе в ногу, если не знать особенностей работы стора в ESM модуле.

Misha Rodshtein
Не прав. В видео даже близко этого нет. Видео объ...

А все понял, просто утро, английский, я думал удивлять будут =) Спасибки.

Misha Rodshtein
Стор в ESM модуле — это всегда синглтон. Кит тут...

Т.е. чтобы избежать подобного (всм чтобы стор не аффектился на разных клиентах), нужно инициализировать стор на ките в режиме браузера? Типа //./stores/client-store.js ... let clientStore; if(Browser) { clientStore = writable(''); } export {clientStore}

Alex Dan
Т.е. чтобы избежать подобного (всм чтобы стор не а...

Просто не мутируйте стор в запросе данных из load функции. Используйте stuff

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

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

Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
А чем вам питонисты не угодили?😂
.
79
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
Всем привет. Поделитесь, пожалуйста, опытом. Есть форма, на которой имеется dbgrid и кнопки: добавить, редактировать, удалить. Если нет записей в dbgrid, то кнопки редактирова...
Евгений
5
type TExtensions<GExtender>=class function GetExtension<GEntityExtenderType>:GEntityExtenderType; end; function TExtensions<GExtender>.GetExtension<GEntityExtenderType...
zamtmn
8
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Всем привет, препод задал вопрос, подскажите пожалуйста, какой адрес инкапсулирует указатель?
Свинка Пеппа
8
Почему никто ещё не написал квантовую виртуальную машину на Windows?
КТ315
7
Вот смотрите у меня есть два стрима сейчас fs, cs: TStream; fs := TFileStream.Create('filename'); cs := TCompressionStream.Create(compression_level, fs); Я хочу сделать так: ...
notme
5
Карта сайта