原生实现一个react-redux的代码示例
网络编程 2021-07-04 16:45www.168986.cn编程入门
这篇文章主要介绍了原生实现一个react-redux的代码示例,长沙网络推广觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
自己动手实现一个react-redux
之前试过自己动手实现一个redux,这篇blog主要记录动手实现一个react-redux的过程。
这个react-redux还有一点点小瑕疵,我以一个计数器作为例子来实现的。
这是目录结构:
这里的connect.js文件就是react-redux。
├─ponent │ connect.js │ counter.js │ └─store index.js
index.js
import React from "react"; import ReactDom,{render} from "react-dom"; import Couter from "./ponent/counter"; import {Provider} from "./ponent/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);
./ponent/connect.js:
import React from "react"; import PropTypes from "prop-types"; //Provider是一个组件 接受一个store属性 将其内容挂载在上下文context //这样后代才可以都有办法拿到 class Provider extends React.Component{ static childContextTypes={ //设置上下文的类型是对象 store:PropTypes.object } getChildContext(){ //获取并设置后代上下文的内容 return {store:this.props.store} } render(){ return this.props.children } } let connect=(mapStateToProps,mapDispatchToProps)=>(p)=>{ return class Proxy extends React.Component{ static contextTypes={ store:PropTypes.object } constructor(props,context){ super(props); //将参数mapStateToProps 的解构赋值 代理组件的状态 this.setState=mapStateToProps(context.store.getState()) } ponentDidMount(){ this.context.store.subscribe(()=>{ this.setState(mapStateToProps(this.context.store.getState())) }) } render(){ return <p {...this.state} {...mapDispatchToProps(this.context.store.dispatch)}/> } } } export {Provider,connect}
./ponent/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)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程