freeCodeCamp/curriculum/challenges/chinese/03-front-end-libraries/react/use-the-lifecycle-method-co...

66 lines
2.2 KiB
Markdown
Raw Blame History

This file contains invisible Unicode characters!

This file contains invisible Unicode characters that may be processed differently from what appears below. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to reveal hidden characters.

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

---
id: 5a24c314108439a4d403617d
title: 使用生命周期方法componentDidMount
challengeType: 6
forumTopicId: 301422
---
# --description--
某些时候,大多数 web 开发人员需要调用 API 端点来检索数据。如果你正在使用 React知道在哪里执行这个动作是很重要的。
React 的最佳实践是在生命周期方法`componentDidMount()`中对服务器进行 API 调用或任何其他调用。将组件装载到 DOM 后会调用此方法。此处对`setState()`的任何调用都将触发组件的重新渲染。在此方法中调用 API 并使用 API 返回的数据设置 state 时,一旦收到数据,它将自动触发更新。
# --instructions--
`componentDidMount()` 中有一个模拟 API 调用。它在 2.5 秒后设置 state以模拟调用服务器检索数据。本示例请求站点的当前活动用户总数。在 render 方法中,把 `activeUsers` 渲染到文字 `Active Users:` 后的 `h1` 标签中。观看预览中发生的事情,随意更改超时时间以查看不同的效果。
# --hints--
`MyComponent`应该渲染一个包含`h1`标签的`div`元素。
```js
assert(
(() => {
const mockedComponent = Enzyme.mount(React.createElement(MyComponent));
return (
mockedComponent.find('div').length === 1 &&
mockedComponent.find('h1').length === 1
);
})()
);
```
组件 state 应该用`componentDidMount`中的延时函数来更新。
```js
assert(
(() => {
const mockedComponent = Enzyme.mount(React.createElement(MyComponent));
return new RegExp('setTimeout(.|\n)+setState(.|\n)+activeUsers').test(
String(mockedComponent.instance().componentDidMount)
);
})()
);
```
`h1`标签应该从`MyComponent`的 state 渲染`activeUsers`值。
```js
async () => {
const mockedComponent = Enzyme.mount(React.createElement(MyComponent));
const first = () => {
mockedComponent.setState({ activeUsers: 1237 });
return mockedComponent.find('h1').text();
};
const second = () => {
mockedComponent.setState({ activeUsers: 1000 });
return mockedComponent.find('h1').text();
};
assert(new RegExp('1237').test(first()) && new RegExp('1000').test(second()));
};
```
# --solutions--