前言的前言
最近被一款来自京东凹凸实验室的多终端开发框架Taro吸粉了,官方对 Taro 的简介是使用React语法,一键生成多终端应用(包括小程序 / H5 / 快应用 / RN 等),而目前 Github 的 Star 也达到了非常可观的数量:4k+。对此,笔者也尝了把鲜,体验了下如何使用Taro写微信小程序。感觉还是十分灵活易用(一气呵成,都没遇到bug!),并且 Taro 还集成了 Redux,解决了小程序没有数据流框架的痛点。
这里贴一个 Taro 的@L_301_0@,有兴趣的同行们可以了解下~也可以和我交流~嘿嘿
前言
Redux是JavaScript 状态容器,提供可预测化的状态管理。一般来说,规模比较大的小程序,页面状态,数据缓存,需要管理的东西太多,这时候引入Redux可以方便的管理这些状态,同一数据,一次请求,应用全局共享。
而Taro也非常友好地为开发者提供了移植的Redux。
依赖
为了更方便地使用Redux
,Taro提供了与react-redux
API 几乎一致的包 @tarojs/redux
来让开发人员获得更加良好的开发体验。
开发前需要安装redux
和@tarojs/redux
以及一些需要用到的中间件
示例
下面通过实现一个Todolist快速上手Redux。
1. 目录结构
首先通过目录划分我们的store
/reducers
/actions
。
分别在文件夹里创建index.js
,作为三个模块的主文件。reducers
和actions
里面的内容我们需要规划好功能之后再来处理。
// 引入需要的中间件
import thunkMiddleware from 'redux-thunk'
import { createLogger } from 'redux-logger'
// 引入根reducers
import rootReducer from '../reducers'
const middlewares = [
thunkMiddleware,createLogger()
]
// 创建store
export default function configStore () {
const store = createStore(rootReducer,applyMiddleware(...middlewares))
return store
}
2. 编写Todos
首先在app.js
中引入一开始定义好的store
,使用@tarojs/redux
中提供的Provider
组件将前面写好的store
接入应用中,这样一来,被Provider
包裹的页面都能共享到应用的store
。
import Index from './pages/index'
import './app.scss'
const store = configStore()
class App extends Component {
...
render () {
return (
接下来就可以正式开始规划Todos应用的主要功能了。
首先我们可以新建constants
文件夹来定义一系列所需的action type
常量。例如Todos我们可以先新增ADD
和DELETE
两个action type
来区分新增和删除Todo指令。
export const DELETE = 'DELETE'
然后开始创建处理这两个指令的reducer
。
import { ADD,DELETE } from '../constants/todos'
// 定义初始状态
const INITIAL_STATE = {
todos: [
{id: 0,text: '第一条todo'}
]
}
function todos (state = INITIAL_STATE,action) {
// 获取当前todos条数,用以id自增
let todoNum = state.todos.length
switch (action.type) {
// 根据指令处理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
中定义函数对应的指令。
export const add = (data) => {
return {
data,type: ADD
}
}
export const del = (id) => {
return {
id,type: DELETE
}
}
完成上述三步之后,我们就可以在Todos应用的主页使用相应action
修改并取得新的store
数据了。来看一眼Todos的index.js
。
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 () {
// 获取未经处理的todos并展示
let { newTodo } = this.state
let { todos,add,del } = this.props
const todosJsx = todos.map(todo => {
return (
return (
export default connect (({ todos }) => ({
todos: todos.todos
}),(dispatch) => ({
add (data) {
dispatch(add(data))
},del (id) {
dispatch(del(id))
}
}))(Index)
最后来看一眼实现的效果~~
内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。