您好,登錄后才能下訂單哦!
自己動(dòng)手實(shí)現(xiàn)一個(gè)react-redux
之前試過(guò)自己動(dòng)手實(shí)現(xiàn)一個(gè)redux,這篇blog主要記錄動(dòng)手實(shí)現(xiàn)一個(gè)react-redux的過(guò)程。
這個(gè)react-redux還有一點(diǎn)點(diǎn)小瑕疵,我以一個(gè)計(jì)數(shù)器作為例子來(lái)實(shí)現(xiàn)的。
這是目錄結(jié)構(gòu):
這里的connect.js文件就是react-redux。
├─component │ connect.js │ counter.js │ └─store index.js
index.js:
import React from "react"; import ReactDom,{render} from "react-dom"; import Couter from "./component/counter"; import {Provider} from "./component/connect" import store from "./store/index" ReactDom.render(<Provider store={store}><Couter/></Provider>,document.getElementById("root"));
./store/index.js:
import {createStore} from "redux"; function reducer(state={number:0},action) { switch (action.type){ case "add": return {number:state.number+action.count} default: return state; } } export default createStore(reducer);
./component/connect.js:
import React from "react"; import PropTypes from "prop-types"; //Provider是一個(gè)組件 接受一個(gè)store屬性 將其內(nèi)容掛載在上下文context //這樣后代才可以都有辦法拿到 class Provider extends React.Component{ static childContextTypes={ //設(shè)置上下文的類(lèi)型是對(duì)象 store:PropTypes.object } getChildContext(){ //獲取并設(shè)置后代上下文的內(nèi)容 return {store:this.props.store} } render(){ return this.props.children } } let connect=(mapStateToProps,mapDispatchToProps)=>(comp)=>{ return class Proxy extends React.Component{ static contextTypes={ store:PropTypes.object } constructor(props,context){ super(props); //將參數(shù)mapStateToProps 的解構(gòu)賦值 代理組件的狀態(tài) this.setState=mapStateToProps(context.store.getState()) } componentDidMount(){ this.context.store.subscribe(()=>{ this.setState(mapStateToProps(this.context.store.getState())) }) } render(){ return <comp {...this.state} {...mapDispatchToProps(this.context.store.dispatch)}/> } } } export {Provider,connect}
./component/counter.js:
import React from "react"; import {connect} from "./connect"; export default class Counter extends React.Component{ constructor(props){ super(props); } render(){ return ( <div> <button onClick={()=>{ this.props.add(5); }}>+</button> {this.props.n} </div> ) } } let mapStateToProps=(state)=>{ return {n:state.number} }; let mapDispatchToProps=(dispatch)=>{ return { add:(count)=>{ dispatch({type:"add",count:count}) } } } export default connect(mapStateToProps,mapDispatchToProps)(Counter)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。