成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

一個(gè)Time TodoList實(shí)例了解redux在wepy中的使用

JackJiang / 1278人閱讀

摘要:描述了如何把轉(zhuǎn)變成下一個(gè)。唯一的要點(diǎn)是當(dāng)變化時(shí)需要返回全新的對(duì)象,而不是修改傳入的參數(shù)。以上是純的使用,使用起來比較雞肋,大量被使用在項(xiàng)目中,封裝庫提供的和可以將和完美結(jié)合,使用非常方便。

@subject: wepy-redux-time-todo
@author: leinov
@date:2018-10-30

wepy-redux-time-todo

Use github地址
git clone [email protected]:leinov/wepy-redux-time-todo.git

npm install

npm run dev

添加到微信開發(fā)者工具里即可運(yùn)行

Wiki 創(chuàng)建項(xiàng)目

wepy是騰訊自出的一套小程序框架,基于Vue寫法,也可以靈活使用第三方庫,對(duì)原生的api也做了部分優(yōu)化,提高了整體代碼的可讀性和可維護(hù)性,也極大的提高了開發(fā)效率,極力推薦使用。首先需要安裝wepy命令,通過命令創(chuàng)建wepy項(xiàng)目,在執(zhí)行下面第二句命令過程中會(huì)有一些問題,在到是否使用redux的問題時(shí)選y,在創(chuàng)建時(shí)就會(huì)加入redux依賴以及store文件夾

npm install wepy-cli -g //安裝全局wepy命令

wepy init standard wepy-redux-time-todo // 創(chuàng)建wepy-redux-time-todo項(xiàng)目
項(xiàng)目結(jié)構(gòu)

執(zhí)行創(chuàng)建命令后會(huì)出現(xiàn)類似以下結(jié)構(gòu)的項(xiàng)目結(jié)構(gòu)(下面是我自己創(chuàng)建文件后的)

 |-- dist // 編譯后執(zhí)行文件夾
 |-- node_modules
 |-- src // 開發(fā)文件夾
 |   |-- components //組件
        |-- sec-title.wpy
     |-- pages //業(yè)務(wù)頁面
        |-- index.wpy
     |-- store // redux
        |-- actions
            |-- index.js
        |-- reducers
            |-- timeReducer.js
            |-- index.js //合并reducer
        |-- types
            |-- index.js
     |-- style //樣式
        |-- weui.scss
     |-- app.wpy //入口
 |-- package.json
Redux概念以及使用

Redux主要的作用是管理復(fù)雜的數(shù)據(jù),多用于操作單頁應(yīng)用中的復(fù)雜狀態(tài),將整個(gè)應(yīng)用的狀態(tài)集中放在一個(gè)容器里統(tǒng)一管理。作為一個(gè)狀態(tài)容器,他就像一個(gè)盒子(store),這個(gè)唯一的盒子(整個(gè)應(yīng)用只有一個(gè)store)里有很多狀態(tài)(state), 都以一個(gè)對(duì)象樹的形式儲(chǔ)存在store 中。 唯一能改變 state 的辦法是觸發(fā) action,action是一個(gè)簡單的對(duì)象,用來描述你想要干什么。reducer是一個(gè)純函數(shù)來根據(jù)action返回的type操作狀態(tài)變化返回新狀態(tài),reducer作為createStore參數(shù)返回最新的store,下面我們通過redux官網(wǎng)的代碼具體描述redux的執(zhí)行過程,

Action

action可以理解為動(dòng)作,用戶希望干什么,比如點(diǎn)擊一個(gè)按鈕讓頁面的數(shù)字加1,切換日期,插入數(shù)組等,總之是一個(gè)希望頁面狀態(tài)發(fā)生改變的行為標(biāo)識(shí)。action用一個(gè)對(duì)象表示,包含一個(gè)必須屬性type

{type:"INCREMENT"} //表示添加動(dòng)作
{type:"DECREMENT"} //表示減法動(dòng)作
{type:"GET_DATA",payload:{}} // 表示獲取數(shù)據(jù)動(dòng)作并掛載一個(gè)數(shù)據(jù)在payload屬性上供reducer使用,多用于異步獲取數(shù)據(jù),也可以用自己的添加其他屬性
Reducer

reducer是一個(gè)形式為 (state, action) => state 的純函數(shù)(純函數(shù)概念:不依賴外部環(huán)境變量,只依賴內(nèi)部參數(shù)、不會(huì)產(chǎn)生副作用、相同的輸入確保相同的輸出)。描述了 action 如何把 state 轉(zhuǎn)變成下一個(gè) state。state 的形式取決于你自己,可以是基本類型、數(shù)組、對(duì)象、甚至是 Immutable.js 生成的數(shù)據(jù)結(jié)構(gòu)。唯一的要點(diǎn)是當(dāng) state 變化時(shí)需要返回全新的對(duì)象,而不是修改傳入的參數(shù)。
下面例子使用 switch 語句和字符串來做判斷,也可以用自己的方式。

function reducer(state = 0, action) {
  switch (action.type) {
  case "INCREMENT":
    return state + 1;
  case "DECREMENT":
    return state - 1;
  default:
    return state;
  }
}
store

redux的createStore方法用于創(chuàng)建應(yīng)用唯一的store,createStore方法的參數(shù)即reducer,用于更新store內(nèi)state樹,通過以下創(chuàng)建就可以把一個(gè)初始的{state:0}的這樣一個(gè)狀態(tài)存入到store中

import { createStore } from "redux";

const store = createStore(reducer);

store有幾個(gè)重要的方法

store.dispatch(action) //派發(fā)事件 表示要干什么

store.getState() // 獲取存儲(chǔ)在store里的所有狀態(tài)(數(shù)據(jù))

store.subscribe(listener) //手動(dòng)監(jiān)聽狀態(tài)變化

dispatch改變狀態(tài)

store.dispatch是改變狀態(tài)的唯一方式,dispatch接受一個(gè)action參數(shù)(做什么),通知reducer需要做出什么樣的改變,再更新整個(gè)store

store.dispatch({INCREMENT:"INCREMENT"}) 

這個(gè)操作會(huì)告訴reducer 當(dāng)前需要給state做加1操作,

獲取state
store.getState() // {state:1}
subscribe監(jiān)聽
store.subscribe(() =>
  console.log(store.getState())
);

在dispatch觸發(fā)狀態(tài)更新后需要通過subscribe監(jiān)聽才能獲得最新的狀態(tài),如果在react中使用則需要把視圖渲染函數(shù)放在監(jiān)聽函數(shù)內(nèi)。

import store from "./redux.js"
store.subscribe(()=>{
  ReactDOM.render(, document.getElementById("root"))
});
以上是純r(jià)edux的使用,使用起來比較雞肋,redux大量被使用在react項(xiàng)目中,封裝庫react-redux提供的Provider和connect可以將react和redux完美結(jié)合,使用非常方便。
Redux在wepy中的使用

通過上面的描述應(yīng)該對(duì)redux有了一定的了解,接下來我們看下redux在小程序框架wepy中如何使用,wepy中需要安裝wepy-redux依賴,類似react-redux,store文件夾下放redux的操作代碼,redux的使用方法都相同,這里我們講下與react使用不一樣的地方

初始化store

首先需要在app.wpy中初始化store

import { setStore } from "wepy-redux"
import configStore from "./store"

const store = configStore()
setStore(store)

wepy中app.wpy編譯后為原生小程序中的app.js,app.js在小程序整個(gè)執(zhí)行生命周期里處于最前端,在小程序初始化時(shí)來創(chuàng)建store,這樣在所有頁面都可以使用,等同于react里的Provider

redux-actions

這里使用redux-actions庫來優(yōu)化reducer里的switch寫法。

import { handleActions } from "redux-actions";
import {
    TIME_CONFIG_DATA, // 學(xué)員
} from "../types/index";

export default handleActions({
    [TIME_CONFIG_DATA](state, action) {
        return {
            ...state,
            timeConfigData: action.newData
        };
    }
}, {
    timeConfigData:[], //state初始值 
});
connect連接到wepy組件上

connect(states, actions) connect有兩個(gè)參數(shù),states是整個(gè)應(yīng)用的狀態(tài),頁面需要使用哪個(gè)狀態(tài)對(duì)應(yīng)獲取該狀態(tài)即可,actions業(yè)務(wù)操作,是wepy-redux對(duì)action的封裝,這里我們不用這種方式,自己在action中手動(dòng)dispatch,如果想要了解詳細(xì)使用可參考wepy-redux

import { connect } from "wepy-redux"
 @connect({
    timeConfigData(state) {
      return state.timeReducer.num
    }
  })
  export default class Index extends wepy.page {
      // ...
    methods = {
      // ...
    }
    // ...
    onLoad() {
    }
  }

使用數(shù)據(jù)

其他方法都與在react中使用相同,通過上面的配置就可以在wepy中使用redux了,詳細(xì)代碼參考code

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/98851.html

相關(guān)文章

  • redux —— 入門實(shí)例 TodoList

    摘要:入門實(shí)例前端技術(shù)真是日新月異,搞完不搭配個(gè)數(shù)據(jù)流都不好意思了。關(guān)于的用法,這只是基礎(chǔ)入門的部分,還有的多的搞基操作,比如異步數(shù)據(jù)流和配合。 redux —— 入門實(shí)例 TodoListshowImg(https://segmentfault.com/img/bVtSeH); Tip 前端技術(shù)真是日新月異,搞完 React 不搭配個(gè)數(shù)據(jù)流都不好意思了。滿懷期待的心去翻了翻 flux,簡直...

    SKYZACK 評(píng)論0 收藏0
  • wepy框架開發(fā)小程序文檔

    摘要:目錄項(xiàng)目構(gòu)建文件使用優(yōu)化之處組件通信的使用注意事項(xiàng)報(bào)錯(cuò)記錄踩坑記錄項(xiàng)目構(gòu)建官方文檔地址鏈接項(xiàng)目源碼地址鏈接項(xiàng)目資料地址鏈接簡單介紹是一個(gè)微信小程序框架,支持模塊化開發(fā),開發(fā)風(fēng)格類似。使用的方式請(qǐng)求小程序原生都將化。 目錄 wepy項(xiàng)目構(gòu)建 wepy文件使用 wepy優(yōu)化之處 wepy組件通信 wepy的API使用 wepy注意事項(xiàng) wepy報(bào)錯(cuò)記錄 wepy踩坑記錄 1. wep...

    Luosunce 評(píng)論0 收藏0
  • 和我一起入坑-React-Native-加入ReduxTodoList

    摘要:之前寫了一篇沒有加入的的小博文。一拆分結(jié)構(gòu)根據(jù)自己的習(xí)慣和固定套路,拆分目錄結(jié)構(gòu)和組件結(jié)構(gòu)。把的導(dǎo)航組件集中放在純粹是個(gè)人習(xí)慣。二代碼實(shí)現(xiàn)入口文件是用來做的數(shù)據(jù)持久化。添加事項(xiàng)后要通知其他組件更新數(shù)據(jù)。 讀前須知 這個(gè)項(xiàng)目是第一次使用Redux的實(shí)例,并不具有專業(yè)性的理論知識(shí)。純粹分享一次開發(fā)過程與心得。之前寫了一篇沒有加入Redux的React Native ToDoList的小博文...

    LucasTwilight 評(píng)論0 收藏0
  • todolist for react redux 學(xué)習(xí)總結(jié)

    摘要:為了提高自己的學(xué)習(xí)效率,避免做一些無用的工作,我也決定以后無論是工作還是學(xué)習(xí)一定要養(yǎng)成定時(shí)總結(jié)的習(xí)慣,而且也要用文字記錄下來,這樣可以時(shí)常復(fù)習(xí),理清邏輯,加深印象。一種解決方法是將對(duì)象作為參數(shù),傳入容器組件。 前言 最近一直在學(xué)習(xí)react技術(shù)棧,相關(guān)的理論和概念基本都了解了,之前也用reactjs寫了幾個(gè)demo,切身體會(huì)到了函數(shù)式編程和組件化開發(fā)的強(qiáng)大之處,但因各種主客觀原因,事后...

    anquan 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<