Taro集成Redux快速上手的方法示例
前言的前言
最近被一款來自京東凹凸實(shí)驗(yàn)室的多終端開發(fā)框架Taro吸粉了,官方對(duì) Taro 的簡(jiǎn)介是使用React語法,一鍵生成多終端應(yīng)用(包括小程序 / H5 / 快應(yīng)用 / RN 等),而目前 Github 的 Star 也達(dá)到了非??捎^的數(shù)量:4k+。對(duì)此,筆者也嘗了把鮮,體驗(yàn)了下如何使用Taro寫微信小程序。感覺還是十分靈活易用(一氣呵成,都沒遇到bug?。⑶?Taro 還集成了 Redux,解決了小程序沒有數(shù)據(jù)流框架的痛點(diǎn)。
這里貼一個(gè) Taro 的官方文檔,有興趣的同行們可以了解下~也可以和我交流~嘿嘿

前言
Redux是JavaScript 狀態(tài)容器,提供可預(yù)測(cè)化的狀態(tài)管理。一般來說,規(guī)模比較大的小程序,頁面狀態(tài),數(shù)據(jù)緩存,需要管理的東西太多,這時(shí)候引入Redux可以方便的管理這些狀態(tài),同一數(shù)據(jù),一次請(qǐng)求,應(yīng)用全局共享。
而Taro也非常友好地為開發(fā)者提供了移植的Redux。
依賴
為了更方便地使用Redux,Taro提供了與react-redux API 幾乎一致的包 @tarojs/redux 來讓開發(fā)人員獲得更加良好的開發(fā)體驗(yàn)。
開發(fā)前需要安裝redux和@tarojs/redux以及一些需要用到的中間件
$ yarn add redux @tarojs/redux redux-action redux-logger # 或者使用 npm $ npm install --save redux @tarojs/redux redux-action redux-logger
示例
下面通過實(shí)現(xiàn)一個(gè)Todolist快速上手Redux。
1. 目錄結(jié)構(gòu)
首先通過目錄劃分我們的store/reducers/actions。

分別在文件夾里創(chuàng)建index.js,作為三個(gè)模塊的主文件。reducers和actions里面的內(nèi)容我們需要規(guī)劃好功能之后再來處理。
// store/index.js
import { createStore, applyMiddleware } from 'redux'
// 引入需要的中間件
import thunkMiddleware from 'redux-thunk'
import { createLogger } from 'redux-logger'
// 引入根reducers
import rootReducer from '../reducers'
const middlewares = [
thunkMiddleware,
createLogger()
]
// 創(chuàng)建store
export default function configStore () {
const store = createStore(rootReducer, applyMiddleware(...middlewares))
return store
}
2. 編寫Todos
首先在app.js中引入一開始定義好的store,使用@tarojs/redux中提供的Provider組件將前面寫好的store接入應(yīng)用中,這樣一來,被Provider包裹的頁面都能共享到應(yīng)用的store。
import Taro, { Component } from '@tarojs/taro'
import { Provider } from '@tarojs/redux'
import configStore from './store'
import Index from './pages/index'
import './app.scss'
const store = configStore()
class App extends Component {
...
render () {
return (
<Provider store={store}>
<Index />
</Provider>
)
}
}
接下來就可以正式開始規(guī)劃Todos應(yīng)用的主要功能了。
首先我們可以新建constants文件夾來定義一系列所需的action type常量。例如Todos我們可以先新增ADD和DELETE兩個(gè)action type來區(qū)分新增和刪除Todo指令。
// src/constants/todos.js export const ADD = 'ADD' export const DELETE = 'DELETE'
然后開始創(chuàng)建處理這兩個(gè)指令的reducer。
// src/reducers/index.js
import { combineReducers } from 'redux'
import { ADD, DELETE } from '../constants/todos'
// 定義初始狀態(tài)
const INITIAL_STATE = {
todos: [
{id: 0, text: '第一條todo'}
]
}
function todos (state = INITIAL_STATE, action) {
// 獲取當(dāng)前todos條數(shù),用以id自增
let todoNum = state.todos.length
switch (action.type) {
// 根據(jù)指令處理todos
case ADD:
return {
...state,
todos: state.todos.concat({
id: todoNum,
text: action.data
})
}
case DELETE:
let newTodos = state.todos.filter(item => {
return item.id !== action.id
})
return {
...state,
todos: newTodos
}
default:
return state
}
}
export default combineReducers({
todos
})
接著在action中定義函數(shù)對(duì)應(yīng)的指令。
// src/actions/index.js
import { ADD, DELETE } from '../constants/todos'
export const add = (data) => {
return {
data,
type: ADD
}
}
export const del = (id) => {
return {
id,
type: DELETE
}
}
完成上述三步之后,我們就可以在Todos應(yīng)用的主頁使用相應(yīng)action修改并取得新的store數(shù)據(jù)了。來看一眼Todos的index.js。
// src/pages/index/index.js
import Taro, { Component } from '@tarojs/taro'
import { View, Input, Text } from '@tarojs/components'
import { connect } from '@tarojs/redux'
import './index.scss'
import { add, del } from '../../actions/index'
class Index extends Component {
config = {
navigationBarTitleText: '首頁'
}
constructor () {
super ()
this.state = {
newTodo: ''
}
}
saveNewTodo (e) {
let { newTodo } = this.state
if (!e.detail.value || e.detail.value === newTodo) return
this.setState({
newTodo: e.detail.value
})
}
addTodo () {
let { newTodo } = this.state
let { add } = this.props
if (!newTodo) return
add(newTodo)
this.setState({
newTodo: ''
})
}
delTodo (id) {
let { del } = this.props
del(id)
}
render () {
// 獲取未經(jīng)處理的todos并展示
let { newTodo } = this.state
let { todos, add, del } = this.props
const todosJsx = todos.map(todo => {
return (
<View className='todos_item'><Text>{todo.text}</Text><View className='del' onClick={this.delTodo.bind(this, todo.id)}>-</View></View>
)
})
return (
<View className='index todos'>
<View className='add_wrap'>
<Input placeholder="填寫新的todo" onBlur={this.saveNewTodo.bind(this)} value={newTodo} />
<View className='add' onClick={this.addTodo.bind(this)}>+</View>
</View>
<View>{ todosJsx }</View>
</View>
)
}
}
export default connect (({ todos }) => ({
todos: todos.todos
}), (dispatch) => ({
add (data) {
dispatch(add(data))
},
del (id) {
dispatch(del(id))
}
}))(Index)
最后來看一眼實(shí)現(xiàn)的效果~~

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript實(shí)現(xiàn)圖片滑動(dòng)切換的代碼示例分享
這篇文章主要介紹了JavaScript實(shí)現(xiàn)圖片滑動(dòng)切換的代碼示例分享,能夠控制包括滑動(dòng)時(shí)間和切換數(shù)量等,需要的朋友可以參考下2016-03-03
JS實(shí)現(xiàn)Fisheye效果動(dòng)感放大菜單代碼
這篇文章主要介紹了JS實(shí)現(xiàn)Fisheye效果動(dòng)感放大菜單代碼,涉及JavaScript事假監(jiān)聽機(jī)制及定時(shí)函數(shù)等相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10
JS前端攻堅(jiān)Eventbus實(shí)現(xiàn)更新示例詳解
這篇文章主要為大家介紹了JS前端攻堅(jiān)Eventbus實(shí)現(xiàn)更新示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
批量下載對(duì)路網(wǎng)圖片并生成html的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄肯螺d對(duì)路網(wǎng)圖片并生成html的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考2016-06-06
JavaScript判斷兩個(gè)對(duì)象是否相等的方法總結(jié)
判斷兩個(gè)對(duì)象是否相等是js中的一個(gè)很常見的內(nèi)容,不同的編程語言和環(huán)境可能會(huì)有不同的方式來實(shí)現(xiàn)這一目標(biāo),在 JavaScript 中,判斷兩個(gè)對(duì)象是否相等主要有以下幾種方法,感興趣的小伙伴跟著小編一起來看看吧2024-08-08

