跳到主要内容
版本:0.82

状态

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

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

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

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

当调用 setState 时,BlinkApp 将重新渲染其组件。通过在计时器内调用 setState,组件将在每次计时器触发时重新渲染。

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