* chore(learn): audit bootstrap * chore(learn): audit FE projects * chore(learn): audit jQuery * chore(learn): audit React * chore(learn): audit react-redux * chore(learn): audit redux * chore(learn): audit sass * fix: apply review suggestions Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> * fix: apply non-suggestions * chore: remove comments from code Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com>
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 5a24c314108439a4d403614d
 | |
| title: Define a Redux Action
 | |
| challengeType: 6
 | |
| forumTopicId: 301440
 | |
| dashedName: define-a-redux-action
 | |
| ---
 | |
| 
 | |
| # --description--
 | |
| 
 | |
| Since Redux is a state management framework, updating state is one of its core tasks. In Redux, all state updates are triggered by dispatching actions. An action is simply a JavaScript object that contains information about an action event that has occurred. The Redux store receives these action objects, then updates its state accordingly. Sometimes a Redux action also carries some data. For example, the action carries a username after a user logs in. While the data is optional, actions must carry a `type` property that specifies the 'type' of action that occurred.
 | |
| 
 | |
| Think of Redux actions as messengers that deliver information about events happening in your app to the Redux store. The store then conducts the business of updating state based on the action that occurred.
 | |
| 
 | |
| # --instructions--
 | |
| 
 | |
| Writing a Redux action is as simple as declaring an object with a type property. Declare an object `action` and give it a property `type` set to the string `'LOGIN'`.
 | |
| 
 | |
| # --hints--
 | |
| 
 | |
| An `action` object should exist.
 | |
| 
 | |
| ```js
 | |
| assert(
 | |
|   (function () {
 | |
|     return typeof action === 'object';
 | |
|   })()
 | |
| );
 | |
| ```
 | |
| 
 | |
| The `action` object should have a key property `type` with value `LOGIN`.
 | |
| 
 | |
| ```js
 | |
| assert(
 | |
|   (function () {
 | |
|     return action.type === 'LOGIN';
 | |
|   })()
 | |
| );
 | |
| ```
 | |
| 
 | |
| # --seed--
 | |
| 
 | |
| ## --seed-contents--
 | |
| 
 | |
| ```js
 | |
| // Define an action here:
 | |
| ```
 | |
| 
 | |
| # --solutions--
 | |
| 
 | |
| ```js
 | |
| const action = {
 | |
|   type: 'LOGIN'
 | |
| }
 | |
| ```
 |