такой пример с интернета:
                  
                  
                  //this is the subscribe function, listens for changes
                  
                  
                  const subscribe = (listener) => {
                  
                  
                      window.addEventListener("storage", listener);
                  
                  
                      return () => {
                  
                  
                        window.removeEventListener("storage", listener);
                  
                  
                      };
                  
                  
                  }
                  
                  
                  //this is the getSnapShot function, returns data subscribed
                  
                  
                  const getSnapShot = () => {
                  
                  
                      localStorage.getItem("example");
                  
                  
                  }
                  
                  
                  //implement the Hook
                  
                  
                  const exampleValue = useSyncExternalStore(subscribe, getSnapShot);
                  
                  
                  
                  
                  
                  Тут я не понял откуда пришло аргумент listener внутри коллбека subscribe
                  
                  
                
Статья тут: https://lo-victoria.com/a-look-at-react-hooks-usesyncexternalstore
> откуда пришло аргумент listener внутри коллбека subscribe Это деталь реализации, пришло из useSyncExternalStore. Ожидается, что 1) есть функция “подписки”, принимает слушателя, который будет вызван в случае изменения состояния; возвращает функцию “отписки”, удаляющую слушателя 2) есть функция получения актуального состояния Примерная логика на примере ручной реализации через простые хуки: function useSyncExternalStore(subscribe, getState) { const [state, setState] = useState(getState); useEffect(() => { const ubsubscribe = subscribe(() => setState(getState())); return ubsubscribe; }, []); return state; }
Обсуждают сегодня