是否可以使用React中的useState()钩子在组件之间共享状态?

我正在React中尝试新的Hook功能。考虑到我有以下两个组件(使用React Hooks)-

const HookComponent = () => {

const [username, setUsername] = useState('Abrar');

const [count, setState] = useState();

const handleChange = (e) => {

setUsername(e.target.value);

}

return (

<div>

<input name="userName" value={username} onChange={handleChange}/>

<p>{username}</p>

<p>From HookComponent: {count}</p>

</div>

)

}

const HookComponent2 = () => {

const [count, setCount] = useState(999);

return (

<div>

<p>You clicked {count} times</p>

<button onClick={() => setCount(count + 1)}>

Click me

</button>

</div>

);

}

Hooks声称要解决在组件之间共享有状态逻辑的问题,但是我发现HookComponent和之间的状态HookComponent2不可共享。例如,countin

的更改HookComponent2不会导致in的更改HookComponent

使用useState()挂钩可以在组件之间共享状态吗?

回答:

如果您指的是组件状态,则挂钩将无法帮助您在组件之间共享它。组件状态是组件本地的。如果您的州生活在上下文中,那么useContext钩子会有所帮助。

从根本上讲,我认为您误解了“在组件之间共享有状态逻辑”这一行。有状态逻辑不同于状态。有状态逻辑是您用来修改状态的东西。例如,某个组件在中componentDidMount()订阅商店,而在中取消订阅componentWillUnmount()。可以在一个挂钩中实现这种订阅/取消订阅行为,需要这种行为的组件可以只使用该挂钩。

如果要在组件之间共享状态,可以使用多种方法,每种方法各有优点:

1.提升状态

提升状态直到两个组件的共同祖先组件。

function Ancestor() {

const [count, setCount] = useState(999);

return <>

<DescendantA count={count} />

<DescendantB count={count} />

</>;

}

这种状态共享方法与使用状态的传统方法从根本上没有什么不同,钩子只是为我们提供了一种声明组件状态的不同方法。

2.上下文

如果后代在组件层次结构中过于深入,并且您不想将状态传递到太多层次,则可以使用Context

API。

有一个useContext你可以在子组件中利用挂机。

3.外部状态管理解决方案

状态管理库,例如Redux或Mobx。然后,您的状态将位于React外部的商店中,组件可以连接/订阅该商店以接收更新。

以上是 是否可以使用React中的useState()钩子在组件之间共享状态? 的全部内容, 来源链接: utcz.com/qa/434263.html

回到顶部