原生實(shí)現(xiàn)一個(gè)react-redux的代碼示例
自己動(dòng)手實(shí)現(xiàn)一個(gè)react-redux
之前試過自己動(dòng)手實(shí)現(xiàn)一個(gè)redux,這篇blog主要記錄動(dòng)手實(shí)現(xiàn)一個(gè)react-redux的過程。
這個(gè)react-redux還有一點(diǎn)點(diǎn)小瑕疵,我以一個(gè)計(jì)數(shù)器作為例子來實(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è)置上下文的類型是對象
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)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
React中Suspense及l(fā)azy()懶加載及代碼分割原理和使用方式
這篇文章主要介紹了React中Suspense及l(fā)azy()懶加載及代碼分割原理和使用方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
useEffect中return函數(shù)的作用和執(zhí)行時(shí)機(jī)解讀
這篇文章主要介紹了useEffect中return函數(shù)的作用和執(zhí)行時(shí)機(jī),具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
基于visual studio code + react 開發(fā)環(huán)境搭建過程
今天通過本文給大家分享基于visual studio code + react 開發(fā)環(huán)境搭建過程,本文給大家介紹的非常詳細(xì),包括react安裝問題及安裝 Debugger for Chrome的方法,需要的朋友跟隨小編一起看看吧2021-07-07
一文詳解React如何處理表單的復(fù)雜驗(yàn)證邏輯
這篇文章主要為大家詳細(xì)介紹了React中如何處理表單的復(fù)雜驗(yàn)證邏輯,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-03-03
react+antd 遞歸實(shí)現(xiàn)樹狀目錄操作
這篇文章主要介紹了react+antd 遞歸實(shí)現(xiàn)樹狀目錄操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
前端開發(fā)使用Ant Design項(xiàng)目評價(jià)
這篇文章主要為大家介紹了前端開發(fā)使用Ant Design項(xiàng)目評價(jià),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
React服務(wù)端渲染和同構(gòu)的實(shí)現(xiàn)
本文主要介紹了React服務(wù)端渲染和同構(gòu)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04

