React-redux: React-Redux: React-Redux: React-Redux: React-Redux: React-Redux
Tutorial mode
-
Render, action, store, connect, dispatch, {mapStateToProps mapDispatchToProps}.
-
You may be confused after reading this, but it doesn’t matter that I have a simple and direct dom of salary increase, just follow through and you will understand
Download this tutorial github.com/Chad97/My-n… — Look at it and you’ll see
A,
- Introduction (have a certain understanding of their own jump two start my guan style tutorial)
For large, complex applications, these two aspects are the most critical. So you can’t write big apps with React. To solve this problem, Facebook introduced the concept of the Flux architecture in 2014, which led to many implementations. In 2015, Redux came along, combining Flux with functional programming, and in a short time it became the hottest front-end architecture.
To be clear, Redux is a useful architecture, but it is not necessary. In fact, for the most part, you can do without it, just React. Someone once said that. “If you don’t know if you need a Redux, you don’t need it.” — Dan Abramov, creator of Redux
Simply put, if your UI layer is very simple and doesn’t have a lot of interaction, Redux is unnecessary and adds complexity. The way the users use it is very simple. There’s no collaboration between the users. There’s not a lot of interaction with the server, and there’s no WebSocket View layer
Store
A Store is just a place where data is stored, so you can think of it as a container. There can only be one Store for the entire app. Redux provides the createStore function to generate a Store.
import { createStore } from 'redux';
const store = createStore(fn);
Copy the code
Action
If the State changes, the View changes. However, the user does not have access to State, only to the View. Therefore, the change in State must be caused by the View. An Action is a notification from the View that the State should change.
An Action is an object. The type attribute is required and represents the name of the Action. Other attributes can be set freely, and the community has a specification to refer to.
const action = {
type: 'ADD_TODO'.payload: 'Learn Redux'
};
Copy the code
In the above code, the name of the Action is ADD_TODO, and the information it carries is the string Learn Redux. In this sense, an Action describes what is currently happening. The only way to change State is to use Action. It ships the data to the Store.
Action Creator
There are as many actions as the View sends messages. If you write it all by hand, it’s a lot of trouble. You can define a function to generate an Action, called Action Creator.
const ADD_TODO = 'add TODO;
function addTodo(text) {
return {
type: ADD_TODO,
text
}
}
Copy the code
const action = addTodo(‘Learn Redux’); In the above code, the addTodo function is an Action Creator.
store.dispatch()
Store.dispatch () is the only way for a View to issue an Action.
import { createStore } from 'redux';
const store = createStore(fn);
store.dispatch({
type: 'ADD_TODO'.payload: 'Learn Redux'
});
Copy the code
In the above code, store.Dispatch takes an Action object as an argument and sends it out. In conjunction with Action Creator, this code can be rewritten as follows.
store.dispatch(addTodo('Learn Redux'));
Reducer
When the Store receives the Action, it must give it a new State for the View to change. The computation process of this State is called Reducer.
Reducer is a function that takes the Action and the current State as parameters and returns a new State.
const reducer = function (state, action) {
// ...
return new_state;
};
Copy the code
The initial State of the entire application, which can be used as the default value for State. Here’s a practical example.
const defaultState = 0;
const reducer = (state = defaultState, action) = > {
switch (action.type) {
case 'ADD':
return state + action.payload;
default:
returnstate; }};const state = reducer(1, {
type: 'ADD'.payload: 2
});
Copy the code
In the preceding code, the reducer function receives the Action named ADD and returns a new State as the result of the addition. The logic for other operations, such as subtraction, can also be implemented depending on the Action.
In practice, the Reducer function does not need to be called manually. The store.dispatch method triggers the Reducer to be automatically executed. To do this, the Store needs to know the Reducer function, and this is done by passing the Reducer to the createStore method when the Store is generated.
import { createStore } from 'redux';
const store = createStore(reducer);
Copy the code
In the preceding code, the createStore accepts the Reducer as an argument and generates a new Store. When store.dispatch sends a new Action, it automatically calls Reducer to obtain the new State.
Why is this function called Reducer? Because it can be used as an argument to the Reduce method of the array. In the following example, a sequence of Action objects is arranged as an array.
const actions = [
{ type: 'ADD'.payload: 0 },
{ type: 'ADD'.payload: 1 },
{ type: 'ADD'.payload: 2}];Copy the code
const total = actions.reduce(reducer, 0); // 3 In the above code, the array actions represents three actions, which are 0, 1, and 2. The reduce method of the array takes the Reducer function as an argument, and the final state 3 is directly obtained.
store.subscribe()
The Store allows you to set the listening function using the store.subscribe method, which automatically executes if State changes.
import { createStore } from 'redux';
const store = createStore(reducer);
store.subscribe(listener);
Copy the code
Apparently, just putting the View’s update function (which in the case of React projects is the component’s render or setState method) into Listen will automatically render the View.
The store.subscribe method returns a function that can be called to unlisten.
let unsubscribe = store.subscribe((a)= >
console.log(store.getState())
);
unsubscribe();
Copy the code
The realization of the Store
The last section introduced the basic concepts involved in Redux, and you can see that The Store provides three methods.
store.getState()
store.dispatch()
store.subscribe()
Copy the code
import { createStore } from ‘redux’; let { subscribe, dispatch, getState } = createStore(reducer); The createStore method also accepts a second parameter, representing the initial State of State. This is usually given by the server.
Let Store = createStore(todoApp, window.state_from_server) In the preceding code, window.state_from_server is the initial state value of the entire application. Note that if this parameter is provided, it overrides the Reducer’s default initial value.
Here is a simple implementation of the createStore method to see how the Store is generated.
const createStore = (reducer) = > {
let state;
let listeners = [];
const getState = (a)= > state;
const dispatch = (action) = > {
state = reducer(state, action);
listeners.forEach(listener= > listener());
};
const subscribe = (listener) = > {
listeners.push(listener);
return (a)= > {
listeners = listeners.filter(l= > l !== listener);
}
};
dispatch({});
return { getState, dispatch, subscribe };
};
Copy the code
- Let’s take a simple counter example
const Counter = ({ value, onIncrement, onDecrement }) = > (
<div>
<h1>{value}</h1>
<button onClick={onIncrement}>+</button>
<button onClick={onDecrement}>-</button>
</div>
);
const reducer = (state = 0, action) = > {
switch (action.type) {
case 'INCREMENT': return state + 1;
case 'DECREMENT': return state - 1;
default: returnstate; }};const store = createStore(reducer);
const render = (a)= > {
ReactDOM.render(
<Counter
value={store.getState()}
onIncrement={()= > store.dispatch({type: 'INCREMENT'})}
onDecrement={() => store.dispatch({type: 'DECREMENT'})}
/>,
document.getElementById('root')
);
};
render();
store.subscribe(render);
Copy the code
Second,
Download this tutorial github.com/Chad97/My-n… — Look at it and you’ll see
In this chapter, let’s take a quick look at react-Redux to start my tutorial
Connect () mapStateToProps mapDispatchToProps
- Let’s cut to the chase
Reacr-redux raise
NPX redux-DOM create a react project with nodeJS or creation-app
- in
src
Create a store under the folder and one inside the storereducer.js
As follows:
import React from 'react';
import { connect } from 'react-redux';
const tiger = 30000// Create salary state
/ / this is the action
const increase = {
type: 'Pay raise'
}
const decrease = {
type: 'Wage deduction'
}
const taxes = {
type: 'tax'
}
/ / this is reducer
const reducer = (state = tiger, action) = > {
switch (action.type) {
case 'Pay raise':
return state += 100;
case 'Wage deduction':
return state -= 100;
case 'tax' :
return state - ((state - 5000) * 0.01)
default:
returnstate; }}export default reducer
Copy the code
Then go to our index.js
import React, { Component } from 'react';
import ReactDOM from 'react-dom';
import App from './App'
import { createStore } from 'redux'
import { Provider } from 'react-redux'
import reducer from './store/reducer'
/ / create a store
const store = createStore(reducer);
ReactDOM.render(
<Provider store={store}>
<App />
</Provider>.document.getElementById('root'))Copy the code
- Let’s talk about Provider, which is a component provided in React-Redux
After the connect method generates the container component, you need the container component to get the state object in order to generate the parameters of the UI component. One solution is to pass the state object as a parameter to the container component. However, doing so can be cumbersome, especially if the container component is at a very deep level, and passing state down from one level to the next is cumbersome. React-redux provides Provider components that allow container components to get state
Remember that he is through the class connect implementation, can let the Provider components of the descendants of the components are loaded to the store, the Guan-style tutorial is simple and rude, to see the implementation principle to see ES6
Ok, now let me go to app. Js, to achieve a pay rise haha ~~~
import React, { Component } from 'react';
import { connect } from 'react-redux';
import Home from './components/Home'
class App extends Component {
componentDidMount () {
// console.log(this.props)
}
render() {
const { PayIncrease, PayDecrease } = this.props
return (
<div className="App">
<h2>{this.props. Tiger}</h2>
<button onClick={PayIncrease}>A promotion and pay increase</button>
<button onClick={PayDecrease}>Late penalty</button>
<Home />
</div>); }}// What data need to be rendered
function mapStateToProps(state) {
return {
tiger: state
}
}
// What actions need to be triggered
function mapDispatchToProps(dispatch) {
return {
PayIncrease: (a)= > dispatch({ type: 'Pay raise' }),
PayDecrease: (a)= > dispatch({ type: 'Wage deduction'}}})export default App = connect(mapStateToProps, mapDispatchToProps)(App)
Copy the code
-
connect
React-redux provides the Connect method for generating container components from UI components. Connect means to connect the two components together.
Remember, the only way to get components to the Store is to connect (). You can understand how to build Bridges. Don’t think too much about it.
Print the wages
Now let me create a new Home. JSX component in SRC/Components envy, after the raise is not to print the salary
import React from 'react';
import { connect } from 'react-redux'
import Counter from './Counter '
class Home extends React.Component {
constructor (props, context){
super(a)this.state = {
}
}
mycl = (a)= > {
alert(this.props.tiger)
}
render() {
return (
<div>
<hr /> <br />
<h1>Home components</h1>
<button onClick= {this.mycl}>Print current salary</button>
<hr /> <br />
<Counter />
</div>
);
}
componentDidMount () {
console.log(this.props)
}
}
// What data need to be rendered
function mapStateToProps(state) {
return {
tiger: state
}
}
// What actions need to be triggered
function mapDispatchToProps(dispatch) {
return {
PayIncrease: (a)= > dispatch({ type: 'Pay raise' }),
PayDecrease: (a)= > dispatch({ type: 'Wage deduction'}}})export default connect(mapStateToProps, mapDispatchToProps)(Home)
Copy the code
tax
Raise finish salary, salary so high should pay tax to pull ~~
import React from 'react';
import { connect } from 'react-redux';
class Counter extends React.Component {
constructor(props) {
super(props);
this.state = {
};
}
render() {
const { Paytaxes } = this.props
return (
<div>
<h2>After tax calculation</h2>
<button onClick={ Paytaxes } >tax</button>
<p>{this.props.tiger}</p>
</div>); }}// What data need to be rendered
function mapStateToProps(state) {
return {
tiger: state
}
}
// What actions need to be triggered
function mapDispatchToProps(dispatch) {
return {
PayIncrease: (a)= > dispatch({ type: 'Pay raise' }),
PayDecrease: (a)= > dispatch({ type: 'Wage deduction' }),
Paytaxes: (a)= > dispatch({ type: 'tax'}}}),export default connect(mapStateToProps, mapDispatchToProps)(Counter)
Copy the code
After the
Dongguan-style tutorial, then go ~~ manual/squint