跳到主要内容

状态

有两种数据类型可以控制组件:propsstateprops 由父组件设置,在组件的整个生命周期中是固定的。对于会改变的数据,我们必须使用 state

通常,你应该在构造函数中初始化 state,然后在需要更改时调用 setState

例如,假设我们想制作一个一直闪烁的文本。文本本身在闪烁组件创建时设置一次,所以文本本身是一个 prop。“文本当前是亮还是灭”会随时间变化,所以这应该保存在 state 中。

在实际应用中,你可能不会用计时器设置状态。你可能会在从服务器获得新数据或用户输入时设置状态。你还可以使用 Redux 或 MobX 等状态容器来控制数据流。在这种情况下,你将使用 Redux 或 MobX 修改状态,而不是直接调用 setState

当调用 setState 时,BlinkApp 将重新渲染其组件。通过在 Timer 中调用 setState,组件将在 Timer 每次计时时重新渲染。

State 的工作方式与 React 中相同,因此有关处理状态的更多详细信息,你可以查看 React.Component API。此时,你可能已经注意到我们的大多数示例都使用默认文本颜色。要自定义文本颜色,你必须学习 Style