前言的前言
最近被一款来自京东凹凸实验室的多终端开发框架Taro吸粉了,官方对 Taro 的简介是使用React语法,一键生成多终端应用(包括小程序 / H5 / 快应用 / RN 等),而目前 Github 的 Star 也达到了非常可观的数量:4k+。对此,笔者也尝了把鲜,体验了下如何使用Taro写微信小程序。感觉还是十分灵活易用(一气呵成,都没遇到bug!),并且 Taro 还集成了 Redux,解决了小程序没有数据流框架的痛点。
这里贴一个 Taro 的官方文档,有兴趣的同行们可以了解下~也可以和我交流~嘿嘿
前言
Redux是JavaScript 状态容器,提供可预测化的状态管理。一般来说,规模比较大的小程序,页面状态,数据缓存,需要管理的东西太多,这时候引入Redux可以方便的管理这些状态,同一数据,一次请求,应用全局共享。
而Taro也非常友好地为开发者提供了移植的Redux。
依赖
为了更方便地使用Redux,Taro提供了与react-redux API 几乎一致的包 @tarojs/redux 来让开发人员获得更加良好的开发体验。
开发前需要安装redux和@tarojs/redux以及一些需要用到的中间件
$ yarn add redux @tarojs/redux redux-action redux-logger # 或者使用 npm $ npm install --save redux @tarojs/redux redux-action redux-logger
示例
下面通过实现一个Todolist快速上手Redux。
1. 目录结构
首先通过目录划分我们的store/reducers/actions。
分别在文件夹里创建index.js,作为三个模块的主文件。reducers和actions里面的内容我们需要规划好功能之后再来处理。
// 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() ] // 创建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 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> ) } }
接下来就可以正式开始规划Todos应用的主要功能了。
首先我们可以新建constants文件夹来定义一系列所需的action type常量。例如Todos我们可以先新增ADD和DELETE两个action type来区分新增和删除Todo指令。
// src/constants/todos.js export const ADD = 'ADD' export const DELETE = 'DELETE'
然后开始创建处理这两个指令的reducer。
// src/reducers/index.js import { combineReducers } from 'redux' 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中定义函数对应的指令。
// 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应用的主页使用相应action修改并取得新的store数据了。来看一眼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.shtml" target="_blank">css' 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 ( <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)
最后来看一眼实现的效果~~
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
Hello World 如何调试 如何新增一个Controller 如何使用models/dao 如何使用models/service
介绍 通过本章节你可以了解到 Vant 的安装方法和基本使用姿势。 安装 通过 npm 安装 在现有项目中使用 Vant 时,可以通过 npm 或 yarn 进行安装: # Vue 2 项目,安装 Vant 2.x 版本: npm i vant -S # Vue 3 项目,安装 Vant 3.x 版本: npm i vant@next -S 通过 CDN 安装 使用 Vant 最简单的方法是直
安装 npm i feart --save-dev # or yarn add feart 引入组件 No.1 : 使用 babel-plugin-import (推荐) # 安装 babel-plugin-import 插件 npm i babel-plugin-import --save-dev // 在 .babelrc 或 babel.config.js 中添加插件配置 {
本节课程提供一个使用 Spark 的快速介绍,首先我们使用 Spark 的交互式 shell(用 Python 或 Scala) 介绍它的 API。当演示如何在 Java, Scala 和 Python 写独立的程序时,看编程指南里完整的参考。 依照这个指南,首先从 Spark 网站下载一个 Spark 发行包。因为我们不会使用 HDFS,你可以下载任何 Hadoop 版本的包。 Spark Sh
快速上手 本节将介绍如何在项目中使用 Element。 使用 vue-cli@3 我们为新版的 vue-cli 准备了相应的 Element 插件,你可以用它们快速地搭建一个基于 Element 的项目。 使用 Starter Kit 我们提供了通用的项目模板,你可以直接使用。对于 Laravel 用户,我们也准备了相应的模板,同样可以直接下载使用。 如果不希望使用我们提供的模板,请继续阅读。 引
新手教程项目:cube-application-guide 遇到问题,先移步 QA 使用 nuxt,请参考示例仓库 脚手架 vue-cli >= 3 如果你正在使用新版本的 Vue CLI vue-cli@3,那么推荐你直接使用 vue-cli-plugin-cube-ui 插件。在你初始化完项目后直接执行 vue add cube-ui 即可。 在执行的时候,会询问一些配置项,这个和老版本的 模