Redux-react-example
提供:Dev Guides
Redux-Reactの例
次に、反応とReduxアプリケーションの小さな例を示します。 小さなアプリの開発を試すこともできます。 増加または減少カウンターのサンプルコードは以下のとおりです-
これは、ストアの作成と、reactアプリコンポーネントのレンダリングを行うルートファイルです。
/src/index.js
import React from 'react'
import { render } from 'react-dom'
import { Provider } from 'react-redux'
import { createStore } from 'redux';
import reducer from '../src/reducer/index'
import App from '../src/App'
import './index.css';
const store = createStore(
reducer,
window.__REDUX_DEVTOOLS_EXTENSION__ &&
window.__REDUX_DEVTOOLS_EXTENSION__()
)
render(
<Provider store = {store}>
<App/>
</Provider>, document.getElementById('root')
)
これは、reactのルートコンポーネントです。 カウンターコンテナコンポーネントを子としてレンダリングする役割を果たします。
/src/app.js
import React, { Component } from 'react';
import './App.css';
import Counter from '../src/container/appContainer';
class App extends Component {
render() {
return (
<div className = "App">
<header className = "App-header">
<Counter/>
</header>
</div>
);
}
}
export default App;
以下は、コンポーネントを反応させるためにReduxの状態を提供する責任があるコンテナコンポーネントです-
/container/counterContainer.js
import { connect } from 'react-redux'
import Counter from '../component/counter'
import { increment, decrement, reset } from '../actions';
const mapStateToProps = (state) => {
return {
counter: state
};
};
const mapDispatchToProps = (dispatch) => {
return {
increment: () => dispatch(increment()),
decrement: () => dispatch(decrement()),
reset: () => dispatch(reset())
};
};
export default connect(mapStateToProps, mapDispatchToProps)(Counter);
以下は、ビューの一部を担当する反応コンポーネントです-
/component/counter.js
import React, { Component } from 'react';
class Counter extends Component {
render() {
const {counter,increment,decrement,reset} = this.props;
return (
<div className = "App">
<div>{counter}</div>
<div>
<button onClick = {increment}>INCREMENT BY 1</button>
</div>
<div>
<button onClick = {decrement}>DECREMENT BY 1</button>
</div>
<button onClick = {reset}>RESET</button>
</div>
);
}
}
export default Counter;
以下は、アクションの作成を担当するアクション作成者です-
/actions/index.js
export function increment() {
return {
type: 'INCREMENT'
}
}
export function decrement() {
return {
type: 'DECREMENT'
}
}
export function reset() {
return { type: 'RESET' }
}
以下に、Reduxの状態を更新するためのreducerファイルのコード行を示しました。
reducer/index.js
const reducer = (state = 0, action) => {
switch (action.type) {
case 'INCREMENT': return state + 1
case 'DECREMENT': return state - 1
case 'RESET' : return 0 default: return state
}
}
export default reducer;
最初は、アプリは次のように見えます-
インクリメントを2回クリックすると、出力画面は次のようになります-
我々は一度それをデクリメントすると、次の画面が表示されます-
また、リセットすると、アプリは初期値に戻り、カウンター値0になります。 これは以下に示されています-
最初のインクリメントアクションが行われたときにRedux開発ツールで何が起こるかを理解しましょう-
アプリの状態は、インクリメントアクションのみがディスパッチされ、残りのアクションがスキップされる時点に移動します。
自分で課題として小さなTodoアプリを開発し、Reduxツールをよりよく理解することをお勧めします。