62 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 5a24c314108439a4d403614b
 | |
| title: Create a Redux Store
 | |
| challengeType: 6
 | |
| forumTopicId: 301439
 | |
| dashedName: create-a-redux-store
 | |
| ---
 | |
| 
 | |
| # --description--
 | |
| 
 | |
| Redux is a state management framework that can be used with a number of different web technologies, including React.
 | |
| 
 | |
| In Redux, there is a single state object that's responsible for the entire state of your application. This means if you had a React app with ten components, and each component had its own local state, the entire state of your app would be defined by a single state object housed in the Redux `store`. This is the first important principle to understand when learning Redux: the Redux store is the single source of truth when it comes to application state.
 | |
| 
 | |
| This also means that any time any piece of your app wants to update state, it **must** do so through the Redux store. The unidirectional data flow makes it easier to track state management in your app.
 | |
| 
 | |
| # --instructions--
 | |
| 
 | |
| The Redux `store` is an object which holds and manages application `state`. There is a method called `createStore()` on the Redux object, which you use to create the Redux `store`. This method takes a `reducer` function as a required argument. The `reducer` function is covered in a later challenge, and is already defined for you in the code editor. It simply takes `state` as an argument and returns `state`.
 | |
| 
 | |
| Declare a `store` variable and assign it to the `createStore()` method, passing in the `reducer` as an argument.
 | |
| 
 | |
| **Note:** The code in the editor uses ES6 default argument syntax to initialize this state to hold a value of `5`. If you're not familiar with default arguments, you can refer to the [ES6 section in the Curriculum](https://learn.freecodecamp.org/javascript-algorithms-and-data-structures/es6/set-default-parameters-for-your-functions) which covers this topic.
 | |
| 
 | |
| # --hints--
 | |
| 
 | |
| The redux store should exist.
 | |
| 
 | |
| ```js
 | |
| assert(typeof store.getState === 'function');
 | |
| ```
 | |
| 
 | |
| The redux store should have a value of 5 for the state.
 | |
| 
 | |
| ```js
 | |
| assert(store.getState() === 5);
 | |
| ```
 | |
| 
 | |
| # --seed--
 | |
| 
 | |
| ## --seed-contents--
 | |
| 
 | |
| ```js
 | |
| const reducer = (state = 5) => {
 | |
|   return state;
 | |
| }
 | |
| 
 | |
| // Redux methods are available from a Redux object
 | |
| // For example: Redux.createStore()
 | |
| // Define the store here:
 | |
| ```
 | |
| 
 | |
| # --solutions--
 | |
| 
 | |
| ```js
 | |
| const reducer = (state = 5) => {
 | |
|   return state;
 | |
| }
 | |
| 
 | |
| const store = Redux.createStore(reducer);
 | |
| ```
 |