摘要:想學習下全家桶中的,剛好看到了阮一峰老師的入門文章,受益匪淺。官方的解釋是是容器,提供可預(yù)測化的狀態(tài)管理。和,寓意為派遣。這是發(fā)出的唯一方法。另外方法會返回一個函數(shù),我們?nèi)绻獬O(jiān)聽,就可以調(diào)用這個函數(shù)。
背景
我:您好!我對此職位感興趣,可以聊聊嗎?
招聘者:您好!感謝關(guān)注。方便發(fā)一份您的簡歷嗎?
幾分鐘后。。。
招聘者:請過用過react嗎?
我:只看過一些項目,沒有實戰(zhàn)開發(fā)過。
招聘者至今杳無音信,再后面跟招聘者聊天基本上都問是否用過react
臥薪嘗膽最近在學習react,記得剛從vue的戰(zhàn)場上廝殺回來,就發(fā)現(xiàn)已經(jīng)跟時代脫軌了。不過幸好,兩個框架思想差別不是很大,看起來也沒有那么的吃力,之前花了一些時間學習了react的語法以及一些簡單使用。想學習下react全家桶中的redux,剛好看到了阮一峰老師的redux入門文章,受益匪淺。于是跟大家一起分享下學習的心得,這個是阮一峰老師的原文文章。
關(guān)于Redux大佬的文章中解釋了rudex什么時候需要不需取用.但是,由于,我是學習,即使知道自己現(xiàn)在目前用不上,但是還是要去搞,要不然需要的時候就書到用時方恨少了[hahaha]。因此,這里我就不跟大家說reudx這個大家伙什么時候要用了,感興趣的骨子們可以移步大佬文章哈。
redux是一種設(shè)計模式(一種行之有效的解決方案,一種解決問題的模板)。它是用來管理狀態(tài)的,就像數(shù)據(jù)庫,用來管理數(shù)據(jù),數(shù)據(jù)進行可以對一系列的操作。我們所有需要共享的狀態(tài)都可以用過redux來進行操作。官方的解釋是:‘是javascript容器,提供可預(yù)測化的狀態(tài)管理。可以讓你構(gòu)建一致化的應(yīng)用,運用于不同的環(huán)境,并且易于測試’
先構(gòu)建一個react項目,直接上手,邊學邊做,這里是通過一個簡單計數(shù)器的應(yīng)用讓大家感受到rudex在項目上如何去應(yīng)用
create-react-app redux-counter
再引入redux
yarn add redux
把準備工作做完了以后,我們就要想了,之前我們說過我們要把所有狀態(tài)都放在rudex里面,但是怎么做呢。Redux給我們提供了一個store來存儲狀態(tài),整個應(yīng)用store是唯一的
Store有以下用法:
提供應(yīng)用需要的state,是一個容器
提供getState()方法獲取state
提供dispatch(action)方法獲取state;
提供subscribe(listener)注冊監(jiān)聽器
現(xiàn)在我們先可以先不必對這些東西有很清楚的了解,只需要知道有這些東西就可以,因為"貧窮會限制我們的想象"。如果我們知道了有,后面有困難就知道好像有東西可以解決。如果我們什么都不知道,那么代碼寫起來就會束手無策,就算百度都不知道怎么去表達我們想要的答案。那么聽我娓娓道來。
在我們剛才構(gòu)建的src目錄下的index.js文件下修改下代碼
//增加的代碼 import { createStore } from "redux"; import counter from "./reducers"; const store = createStore(counter); //修改的代碼 ReactDOM.render(({ store.getState() }), document.getElementById("root"));
createStore是redux提供提供的函數(shù)用來生成store,它接收對store進行處理的reducer作為參數(shù),reducer我們先不說,稍后再講。
我們現(xiàn)在用counter代替下,counter現(xiàn)在就是處理這個計數(shù)器的函數(shù),待會兒我們會在src下建一個reducers文件夾里面會暴露出counter這個函數(shù)。我們在render中讓view層顯示獲取到state通過 store.getState()
那么我們在src下新建一個reducers文件夾,里面新建一個index.js文件,代碼如下:
export default (state = 0, action) => { console.log(action.type) switch(action.type) { case "INCREMENT": return state + 1; case "DECREMENT": return state - 1; default: return state; } }
這里提供狀態(tài),提供可以被action計算的狀態(tài),視圖與狀態(tài)一一對應(yīng)。
Redux首次執(zhí)行時,state為undefined,此時我們可以借機設(shè)置并返回應(yīng)用初始的state,因此這里我們用state=0 來初始化狀態(tài),在這里我們初始化狀態(tài)直接在函數(shù)參數(shù)中通過(state=0),這是不好的做法,后面我們會把初始狀態(tài)定義給一個常量,這里我們就先這樣寫。
然后通過action來改變狀態(tài),當我們在判斷action的時候往往用switch進行操作。但我們用戶要操作數(shù)據(jù)的時候,就會觸發(fā)action。
到這里運行下項目,我們便可以看到界面上出現(xiàn)了一個"0".
接著往下,我們再來寫一個用戶操作的組件Counter,在components下新建一個Counter.js
import React,{ Component } from "react"; class Counter extends Component { render () { const { value,onIncrement,onDecrement } = this.props; return (Clicked: { value } times { " "}) } } export default Counter;
我們想實現(xiàn)能加能減。待會兒我們就需要在父組件中把兩個方法以及state傳遞過來。
src下的index文件更改為如下:
import React from "react"; import ReactDOM from "react-dom"; import "./index.css"; import App from "./App"; import * as serviceWorker from "./serviceWorker"; import { createStore } from "redux"; import Counter from "./components/Counter" import counter from "./reducers"; const store = createStore(counter); const rootEl = document.getElementById("root") const render = () => { ReactDOM.render(store.dispatch({ type: "INCREMENT" })} onDecrement={() => store.dispatch({ type: "DECREMENT" })} />,rootEl) } render(); store.subscribe(render) serviceWorker.unregister(); //多帶帶構(gòu)建狀態(tài)樹,狀態(tài)是跟UI統(tǒng)一的
在這里我們又兩個陌生的api。dispatch和subscribe.
dispatch,寓意為派遣。如果我們state里面的狀態(tài)要改變,我們就必須要通過store.dispatch方法。這是View發(fā)出Action的唯一方法。沒有規(guī)矩就不成方圓,這個狀態(tài)是大家共享的,因此任何組件想要改變它,這都是唯一途徑.它接收一個action。如果需要詳解了解dispatch如何通過action觸發(fā)reducer,可以看下源碼。
store.subscribe(),在這里,store允許我們設(shè)置一個監(jiān)聽函數(shù),何為監(jiān)聽,就是state改變了,我view要做出改變,這才是MVVM。在React中,我們就監(jiān)聽render方法,只要state改變了,render就幫你把頁面重新渲染。另外store.subscribe()方法會返回一個函數(shù),我們?nèi)绻獬O(jiān)聽,就可以調(diào)用這個函數(shù)。做法如下:
let unsubscribe = store.subscribe(() => { console.log(store.getState()) }) unsubscribe;
到這里我們就已經(jīng)完成了一個redux的小應(yīng)用
總結(jié)redux其實就三大概念。reducer、action、store
我們先說action,action其實最簡單了,就是一個集中便簽,用來管理actionsTypes,store.dispath的時候就告訴action你要干嘛。
接下來就是reducer了,通過actio得到的操作,reducer就來執(zhí)行相應(yīng)的操作,并把最終的數(shù)據(jù)再給store。那么store,很顯然,他把action和reducer聯(lián)系起來了,而且他還提供方法給我們操作數(shù)據(jù),給視圖提供數(shù)據(jù)
這里有這次實踐的源碼,有需要的可以采之
未完待續(xù)...
*
小生才疏學淺,大三學徒一枚。文章中定有許多不嚴謹之處或是不正確的理解,還望大佬們不吝指教。同時也希望大佬能分享一些自己關(guān)于這一塊覺得不錯的干貨鏈接。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/100314.html
摘要:是微軟開發(fā)的的超集,兼容,可以載入代碼然后運行。可處理已有的代碼,并只對其中的代碼進行編譯小編我決定使用白鷺引擎開發(fā)游戲,在開發(fā)游戲之前學習一下,目前它的可視化工具已經(jīng)可以打多端包了是一套完整的游戲開發(fā)解決方案。中包含多個工具以及項目。 TypeScript 是微軟開發(fā)的 JavaScript 的超集,TypeScript兼容JavaScript,可以載入JavaScript代碼然后運...
摘要:越開源越幸運項目地址源碼各位覺得還闊以的話,點下分享不易,技術(shù)棧前端后端部署項目簡介電商整套系統(tǒng)商家管理后臺小程序客戶端小程序端介紹商品模塊功能秒殺,算法推薦和猜你喜歡,收藏,選擇,購物車,評論,會員活動模塊功能優(yōu)惠套餐,商家推薦,最新活動 越開源越幸運 項目地址 GitHub源碼:https://github.com/371854496/...各位覺得還闊以的話,點下Star,分享不...
摘要:重載概念在同一個類中,可以定義多個名稱相同,參數(shù)列表不同的函數(shù),這種情況較做函數(shù)的重載調(diào)用通過函數(shù)名和參數(shù)列表共同確定一個函數(shù)好處讓開發(fā)者需要記憶的函數(shù)名大大降低,提高開發(fā)效率。 函數(shù)的概述 1.函數(shù)定義: 能完成特定功能的代碼段就是函數(shù),每一個函數(shù)都是一個獨立的小功能 2.為什么要有: 如果沒有函數(shù),在實現(xiàn)一個功能時候,就要寫一遍這個邏輯, 如果功能多次使用,就會產(chǎn)生大量重復(fù)的代碼....
閱讀 2703·2023-04-25 19:13
閱讀 4041·2021-09-22 15:34
閱讀 3061·2019-08-30 14:23
閱讀 1470·2019-08-29 17:17
閱讀 1611·2019-08-29 16:05
閱讀 1544·2019-08-29 13:26
閱讀 1223·2019-08-29 13:19
閱讀 561·2019-08-29 13:16