такой пример с интернета:
//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; }
Обсуждают сегодня