ReactJS - Menggunakan Flux
Pada bab ini, kita akan mempelajari bagaimana mengimplementasikan pola fluks pada aplikasi React. Kami akan menggunakanReduxkerangka. Tujuan dari bab ini adalah untuk menyajikan contoh paling sederhana dari setiap bagian yang dibutuhkan untuk menghubungkanRedux dan React.
Langkah 1 - Instal Redux
Kami akan menginstal Redux melalui command prompt jendela.
C:\Users\username\Desktop\reactApp>npm install --save react-redux
Langkah 2 - Buat File dan Folder
Pada langkah ini, kami akan membuat folder dan file untuk file actions, reducers, dan components. Setelah kita selesai dengan itu, seperti inilah struktur foldernya.
C:\Users\Tutorialspoint\Desktop\reactApp>mkdir actions
C:\Users\Tutorialspoint\Desktop\reactApp>mkdir components
C:\Users\Tutorialspoint\Desktop\reactApp>mkdir reducers
C:\Users\Tutorialspoint\Desktop\reactApp>type nul > actions/actions.js
C:\Users\Tutorialspoint\Desktop\reactApp>type nul > reducers/reducers.js
C:\Users\Tutorialspoint\Desktop\reactApp>type nul > components/AddTodo.js
C:\Users\Tutorialspoint\Desktop\reactApp>type nul > components/Todo.js
C:\Users\Tutorialspoint\Desktop\reactApp>type nul > components/TodoList.js
Langkah 3 - Tindakan
Tindakan adalah objek JavaScript yang digunakan typeproperti untuk menginformasikan tentang data yang harus dikirim ke toko. Kami sedang mendefinisikanADD_TODOtindakan yang akan digunakan untuk menambahkan item baru ke daftar kami. ItuaddTodo function adalah pencipta tindakan yang mengembalikan tindakan kita dan menetapkan id untuk setiap item yang dibuat.
tindakan / tindakan. js
export const ADD_TODO = 'ADD_TODO'
let nextTodoId = 0;
export function addTodo(text) {
return {
type: ADD_TODO,
id: nextTodoId++,
text
};
}
Langkah 4 - Pengurang
Sementara tindakan hanya memicu perubahan dalam aplikasi, file reducerstentukan perubahan itu. Kami menggunakanswitch pernyataan untuk mencari a ADD_TODOtindakan. Peredam adalah fungsi yang mengambil dua parameter (state dan action) untuk menghitung dan mengembalikan status yang diperbarui.
Fungsi pertama akan digunakan untuk membuat item baru, sedangkan fungsi kedua akan mendorong item tersebut ke daftar. Menjelang akhir, kami menggunakancombineReducers fungsi helper di mana kita dapat menambahkan reduksi baru yang mungkin kita gunakan di masa mendatang.
reduksi / reduksi.js
import { combineReducers } from 'redux'
import { ADD_TODO } from '../actions/actions'
function todo(state, action) {
switch (action.type) {
case ADD_TODO:
return {
id: action.id,
text: action.text,
}
default:
return state
}
}
function todos(state = [], action) {
switch (action.type) {
case ADD_TODO:
return [
...state,
todo(undefined, action)
]
default:
return state
}
}
const todoApp = combineReducers({
todos
})
export default todoApp
Langkah 5 - Simpan
Toko adalah tempat yang menyimpan status aplikasi. Sangat mudah untuk membuat toko setelah Anda memiliki reduksi. Kami melewati properti toko keprovider elemen, yang membungkus komponen rute kami.
main.js
import React from 'react'
import { render } from 'react-dom'
import { createStore } from 'redux'
import { Provider } from 'react-redux'
import App from './App.jsx'
import todoApp from './reducers/reducers'
let store = createStore(todoApp)
let rootElement = document.getElementById('app')
render(
<Provider store = {store}>
<App />
</Provider>,
rootElement
)
Langkah 6 - Komponen Root
Itu Appkomponen adalah komponen akar aplikasi. Hanya komponen root yang harus mengetahui redux. Bagian penting yang harus diperhatikan adalahconnect fungsi yang digunakan untuk menghubungkan komponen root kita App ke store.
Fungsi ini membutuhkan selectberfungsi sebagai argumen. Pilih fungsi mengambil status dari toko dan mengembalikan alat peraga (visibleTodos) yang dapat kita gunakan di komponen kita.
App.jsx
import React, { Component } from 'react'
import { connect } from 'react-redux'
import { addTodo } from './actions/actions'
import AddTodo from './components/AddTodo.js'
import TodoList from './components/TodoList.js'
class App extends Component {
render() {
const { dispatch, visibleTodos } = this.props
return (
<div>
<AddTodo onAddClick = {text =>dispatch(addTodo(text))} />
<TodoList todos = {visibleTodos}/>
</div>
)
}
}
function select(state) {
return {
visibleTodos: state.todos
}
}
export default connect(select)(App);
Langkah 7 - Komponen Lainnya
Komponen ini seharusnya tidak mengetahui redux.
komponen / AddTodo.js
import React, { Component, PropTypes } from 'react'
export default class AddTodo extends Component {
render() {
return (
<div>
<input type = 'text' ref = 'input' />
<button onClick = {(e) => this.handleClick(e)}>
Add
</button>
</div>
)
}
handleClick(e) {
const node = this.refs.input
const text = node.value.trim()
this.props.onAddClick(text)
node.value = ''
}
}
komponen / Todo.js
import React, { Component, PropTypes } from 'react'
export default class Todo extends Component {
render() {
return (
<li>
{this.props.text}
</li>
)
}
}
komponen / TodoList.js
import React, { Component, PropTypes } from 'react'
import Todo from './Todo.js'
export default class TodoList extends Component {
render() {
return (
<ul>
{this.props.todos.map(todo =>
<Todo
key = {todo.id}
{...todo}
/>
)}
</ul>
)
}
}
Saat kami memulai aplikasi, kami akan dapat menambahkan item ke daftar kami.