国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Taro集成Redux快速上手

DevYK / 1305人閱讀

摘要:開發前需要安裝和以及一些需要用到的中間件如果在要使用的話,還需要引入這個庫或者使用示例下面通過實現一個快速上手。然后開始創建處理這兩個指令的。完成上述三步之后,我們就可以在應用的主頁使用相應修改并取得新的數據了。

本文適合有一定React和Redux基礎的用戶閱讀。
前言的前言

最近被一款來自京東凹凸實驗室的多終端開發框架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以及一些需要用到的中間件

ps:如果在h5要使用redux的話,還需要引入nerv-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,作為三個模塊的主文件。reducersactions里面的內容我們需要規劃好功能之后再來處理。

// 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 (
      
        
        
    )
  }
}

接下來就可以正式開始規劃Todos應用的主要功能了。

首先我們可以新建constants文件夾來定義一系列所需的action type常量。例如Todos我們可以先新增ADDDELETE兩個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.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 (
        {todo.text}-
      )
    })

    return (
      
        
          
          +
        
        { todosJsx }  
      
    )
  }
}

export default connect (({ todos }) => ({
  todos: todos.todos
}), (dispatch) => ({
  add (data) {
    dispatch(add(data))
  },
  del (id) {
    dispatch(del(id))
  }
}))(Index)

最后來看一眼實現的效果~~

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/95578.html

相關文章

  • 新的小程序開發框架?- Taro的深度實踐體驗

    摘要:作為兩個小程序開發框架都使用過,并應用在生產環境里的人,自然是要比較一下兩者的異同點。在這里與當前很流行的小程序開發框架之一進行簡單對比,主要還是為了方便大家更快速地了解,從而選擇更適合自己的開發方式。 前言 前陣子,來自我們凹凸實驗室的遵循 React 語法規范的多端開發方案 - Taro終于對外開源了,歡迎圍觀star(先打波廣告)。作為第一批使用了Taro開發的TOPLIFE小程...

    maochunguang 評論0 收藏0
  • Taro 優秀學習資源匯總

    摘要:多端統一開發框架優秀學習資源匯總官方資源項目倉庫官方文檔項目倉庫官方文檔微信小程序官方文檔百度智能小程序官方文檔支付寶小程序官方文檔字節跳動小程序官方文檔文章教程不敢閱讀包源碼帶你揭秘背后的哲學從到構建適配不同端微信小程序等的應用小程序最 Awesome Taro 多端統一開發框架 Taro 優秀學習資源匯總 showImg(https://segmentfault.com/img/r...

    toddmark 評論0 收藏0
  • Taro快速上手教程(一)

    摘要:個人所有文章同步到前言最近公司準備開發幾款可以在微信小程序端和端同時運行的一套商城,接著就是任務下發嘍,但是有一點,時間緊任務重,直接說其他的不管,反正幾個星期之內必須上線,頭疼。 個人所有文章同步到:https://github.com/zhengzhuan... 前言 最近公司Boss準備開發幾款可以在微信小程序端和H5端同時運行的一套商城,接著就是任務下發嘍,但是有一點,時間緊任...

    pakolagij 評論0 收藏0
  • 5分鐘快速上手多端開發框架Taro

    摘要:第一步安裝鏈接安裝完成后在命令行輸入,顯示版本號即安裝成功,如下圖第二步安裝在命令行輸入或在這里我用的是,感謝阿里提供的國內鏡像安裝完成后入下圖所示輸入,會顯示當前安裝的版本,如下圖第三步使用命令創建模板項目打開目標文件夾后輸入命令 第一步:安裝node.js(鏈接https://nodejs.org/en/) 安裝完成后在命令行輸入node -v,顯示版本號即安裝成功,如下圖 sh...

    li21 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<