欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Taro集成Redux快速上手的方法示例

 更新時間:2018年06月21日 13:46:48   作者:yvonne  
這篇文章主要介紹了Taro集成Redux快速上手的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言的前言

最近被一款來自京東凹凸實驗室的多終端開發(fā)框架Taro吸粉了,官方對 Taro 的簡介是使用React語法,一鍵生成多終端應(yīng)用(包括小程序 / H5 / 快應(yīng)用 / RN 等),而目前 Github 的 Star 也達(dá)到了非常可觀的數(shù)量:4k+。對此,筆者也嘗了把鮮,體驗了下如何使用Taro寫微信小程序。感覺還是十分靈活易用(一氣呵成,都沒遇到bug?。?,并且 Taro 還集成了 Redux,解決了小程序沒有數(shù)據(jù)流框架的痛點(diǎn)。

這里貼一個 Taro 的官方文檔,有興趣的同行們可以了解下~也可以和我交流~嘿嘿

前言

Redux是JavaScript 狀態(tài)容器,提供可預(yù)測化的狀態(tài)管理。一般來說,規(guī)模比較大的小程序,頁面狀態(tài),數(shù)據(jù)緩存,需要管理的東西太多,這時候引入Redux可以方便的管理這些狀態(tài),同一數(shù)據(jù),一次請求,應(yīng)用全局共享。

而Taro也非常友好地為開發(fā)者提供了移植的Redux。

依賴

為了更方便地使用Redux,Taro提供了與react-redux API 幾乎一致的包 @tarojs/redux 來讓開發(fā)人員獲得更加良好的開發(fā)體驗。

開發(fā)前需要安裝redux@tarojs/redux以及一些需要用到的中間件

$ yarn add redux @tarojs/redux redux-action redux-logger
# 或者使用 npm
$ npm install --save redux @tarojs/redux redux-action redux-logger

示例

下面通過實現(xiàn)一個Todolist快速上手Redux。

1. 目錄結(jié)構(gòu)

首先通過目錄劃分我們的store/reducers/actions。

分別在文件夾里創(chuàng)建index.js,作為三個模塊的主文件。reducersactions里面的內(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我們可以先新增ADDDELETE兩個action type來區(qū)分新增和刪除Todo指令。

// src/constants/todos.js

export const ADD = 'ADD'
export const DELETE = 'DELETE'

然后開始創(chuàng)建處理這兩個指令的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ù)對應(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)

最后來看一眼實現(xiàn)的效果~~

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JavaScript實現(xiàn)圖片滑動切換的代碼示例分享

    JavaScript實現(xiàn)圖片滑動切換的代碼示例分享

    這篇文章主要介紹了JavaScript實現(xiàn)圖片滑動切換的代碼示例分享,能夠控制包括滑動時間和切換數(shù)量等,需要的朋友可以參考下
    2016-03-03
  • JS實現(xiàn)Fisheye效果動感放大菜單代碼

    JS實現(xiàn)Fisheye效果動感放大菜單代碼

    這篇文章主要介紹了JS實現(xiàn)Fisheye效果動感放大菜單代碼,涉及JavaScript事假監(jiān)聽機(jī)制及定時函數(shù)等相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-10-10
  • Webpack介紹和基本使用指南

    Webpack介紹和基本使用指南

    Webpack 本身功能比較少,只能處理 js 資源,一旦遇到 css 等其他資源就會報錯,本文給大家講解Webpack介紹和基本使用指南,感興趣的朋友一起看看吧
    2024-02-02
  • JS前端攻堅Eventbus實現(xiàn)更新示例詳解

    JS前端攻堅Eventbus實現(xiàn)更新示例詳解

    這篇文章主要為大家介紹了JS前端攻堅Eventbus實現(xiàn)更新示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • JS組件Bootstrap按鈕組與下拉按鈕詳解

    JS組件Bootstrap按鈕組與下拉按鈕詳解

    這篇文章主要為大家介紹了JS組件Bootstrap按鈕組與下拉按鈕的相關(guān)資料,感興趣的小伙伴們可以參考一下
    2016-05-05
  • 批量下載對路網(wǎng)圖片并生成html的實現(xiàn)方法

    批量下載對路網(wǎng)圖片并生成html的實現(xiàn)方法

    下面小編就為大家?guī)硪黄肯螺d對路網(wǎng)圖片并生成html的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考
    2016-06-06
  • 微信小程序裁剪頭像插件使用方法詳解

    微信小程序裁剪頭像插件使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了微信小程序裁剪頭像插件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • JavaScript判斷兩個對象是否相等的方法總結(jié)

    JavaScript判斷兩個對象是否相等的方法總結(jié)

    判斷兩個對象是否相等是js中的一個很常見的內(nèi)容,不同的編程語言和環(huán)境可能會有不同的方式來實現(xiàn)這一目標(biāo),在 JavaScript 中,判斷兩個對象是否相等主要有以下幾種方法,感興趣的小伙伴跟著小編一起來看看吧
    2024-08-08
  • js時間日期格式化封裝函數(shù)

    js時間日期格式化封裝函數(shù)

    這里給大家推薦一款自己封裝的js時間日期格式化的函數(shù),非常的簡潔實用,分享給有需要的小伙伴
    2014-12-12
  • 通過JavaScript下載文件到本地的方法(單文件)

    通過JavaScript下載文件到本地的方法(單文件)

    這篇文章主要介紹了通過JavaScript下載文件到本地的方法(單文件),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03

最新評論