我正在使用useContext钩子制作一个与其他组件共享状态的组件。
现在这个组件也将状态保存到本地存储。
var initialState = {
avatar: '/static/uploads/profile-avatars/placeholder.jpg',
isRoutingVisible: false,
removeRoutingMachine: false,
markers: [],
currentMap: {}
};
var UserContext = React.createContext();
function setLocalStorage(key, value) {
function isJson(item) {
item = typeof item !== 'string' ? JSON.stringify(item) : item;
try {
item = JSON.parse(item);
} catch (e) {
return false;
}
if (typeof item === 'object' && item !== null) {
return true;
}
return false;
}
try {
window.localStorage.setItem(key, JSON.stringify(value));
} catch (errors) {
// catch possible errors:
console.log(errors);
}
}
function getLocalStorage(key, initialValue) {
try {
const value = window.localStorage.getItem(key);
return value ? JSON.parse(value) : initialValue;
} catch (e) {
return initialValue;
}
}
function UserProvider({ children }) {
const [user, setUser] = useState(() => getLocalStorage('user', initialState));
在我声明一些 useEffect 钩子之后:
const [
isLengthOfUserMarkersLessThanTwo,
setIsLengthOfUserMarkersLessThanTwo
] = useState(true);
useEffect(() => {
setLocalStorage('user', user);
}, [user]);
useEffect(() => {
console.log('user.isRoutingVisibile ', user.isRoutingVisibile);
}, [user.isRoutingVisibile]);
useEffect(() => {
console.log('user.markers.length ', user.markers.length);
if (user.markers.length === 2) {
setIsLengthOfUserMarkersLessThanTwo(false);
}
return () => {};
}, [JSON.stringify(user.markers)]
);
最后一个钩子是头刮板,我在依赖项中传递一个数组,当数组长度达到 2 时,我想做出react(ha!)做一些事情。
当它到达那里时,我有一个 useState 钩子,它将改变一个变量的值。
const [
isLengthOfUserMarkersLessThanTwo,
setIsLengthOfUserMarkersLessThanTwo
] = useState(true);
我有一个函数,我想将它传递给另一个组件,该函数只能在三元返回 true 时触发。
现在,尽管 Array 的长度变为 2,setIsLengthOfUserMarkersLessThanTwo但不会将变量更改为false
return (
<UserContext.Provider
value={{
setUserMarkers: marker => {
console.log('marker ', marker);
console.log(
'isLengthOfUserMarkersLessThanTwo ',
isLengthOfUserMarkersLessThanTwo
);
isLengthOfUserMarkersLessThanTwo === true
? setUser(user => ({
...user,
markers: [...user.markers, marker]
}))
: () => null;
},
}}
>
{children}
</UserContext.Provider>
);
先感谢您!