mirror of
https://github.com/status-im/react-native.git
synced 2025-01-28 10:14:49 +00:00
29404f087e
Summary: If the new state depends on the previous state, if I remember correctly, it’s safer to use `setState()` with a function argument to ensure we’re not reading from an outdated `state`. Thanks for submitting a PR! Please read these instructions carefully: - [x] Explain the **motivation** for making this change. - [x] Provide a **test plan** demonstrating that the code is solid. - [x] Match the **code formatting** of the rest of the codebase. - [x] Target the `master` branch, NOT a "stable" branch. The tutorial suggests to use `setState()` with an object argument when the new state depends on the previous state. In such situations, it’s preferable to use a function to ensure the previous state is up-to-date. Updates documentation only, so there are no additional tests. Rendering the site. Sign the [CLA][2], if you haven't already. Small pull requests are much easier to review and more likely to get merged. Make sure th Closes https://github.com/facebook/react-native/pull/13358 Differential Revision: D4852404 Pulled By: hramos fbshipit-source-id: 834759e16bcfbd5a8de71bf0c56f2b154f3321e1
64 lines
2.5 KiB
Markdown
64 lines
2.5 KiB
Markdown
---
|
|
id: state
|
|
title: State
|
|
layout: docs
|
|
category: The Basics
|
|
permalink: docs/state.html
|
|
next: style
|
|
previous: props
|
|
---
|
|
|
|
There are two types of data that control a component: `props` and `state`. `props` are set by the parent and they are fixed throughout the lifetime of a component. For data that is going to change, we have to use `state`.
|
|
|
|
In general, you should initialize `state` in the constructor, and then call `setState` when you want to change it.
|
|
|
|
For example, let's say we want to make text that blinks all the time. The text itself gets set once when the blinking component gets created, so the text itself is a `prop`. The "whether the text is currently on or off" changes over time, so that should be kept in `state`.
|
|
|
|
```ReactNativeWebPlayer
|
|
import React, { Component } from 'react';
|
|
import { AppRegistry, Text, View } from 'react-native';
|
|
|
|
class Blink extends Component {
|
|
constructor(props) {
|
|
super(props);
|
|
this.state = {showText: true};
|
|
|
|
// Toggle the state every second
|
|
setInterval(() => {
|
|
this.setState(previousState => {
|
|
return { showText: !previousState.showText };
|
|
});
|
|
}, 1000);
|
|
}
|
|
|
|
render() {
|
|
let display = this.state.showText ? this.props.text : ' ';
|
|
return (
|
|
<Text>{display}</Text>
|
|
);
|
|
}
|
|
}
|
|
|
|
class BlinkApp extends Component {
|
|
render() {
|
|
return (
|
|
<View>
|
|
<Blink text='I love to blink' />
|
|
<Blink text='Yes blinking is so great' />
|
|
<Blink text='Why did they ever take this out of HTML' />
|
|
<Blink text='Look at me look at me look at me' />
|
|
</View>
|
|
);
|
|
}
|
|
}
|
|
|
|
AppRegistry.registerComponent('BlinkApp', () => BlinkApp);
|
|
```
|
|
|
|
In a real application, you probably won't be setting state with a timer. You might set state when you have new data arrive from the server, or from user input. You can also use a state container like [Redux](http://redux.js.org/index.html) to control your data flow. In that case you would use Redux to modify your state rather than calling `setState` directly.
|
|
|
|
When setState is called, BlinkApp will re-render its Component. By calling setState within the Timer, the component will re-render every time the Timer ticks.
|
|
|
|
State works the same way as it does in React, so for more details on handling state, you can look at the [React.Component API](https://facebook.github.io/react/docs/component-api.html).
|
|
At this point, you might be annoyed that most of our examples so far use boring default black text. To make things more beautiful, you will have to [learn about Style](docs/style.html).
|