之前学习了react,也学习了redux,那么react-redux是什么呢?实际上他是一个第三方的模块,他可以帮助我们在react之中更加方便的使用redux。首先如果想用react-redux,先要安装react-redux.
import React from 'react';
import ReactDOM from 'react-dom';
import TodoList from './TodoList';
import { Provider } from 'react-redux'; const App = (
  <Provider>
    <TodoList />
  </Provider>
) ReactDOM.render(App, document.getElementById('root'));
我们使用react-redux的核心api就是Provider。他的作用是什么呢?
import React from 'react';
import ReactDOM from 'react-dom';
import TodoList from './TodoList';
import { Provider } from 'react-redux';
import store from './store'; const App = (
  <Provider store={store}>
    <TodoList />
  </Provider>
) ReactDOM.render(App, document.getElementById('root'));
加入了store,是可以正确执行的。首先Provider这个容器连接了store,那么Provider里面所有的组件都有能力去获取store。Provider已经把store提供给了内部所有的组件了。那么todoList里面去获取store里面的数据就不用这么困难了。
react-redux第二个核心api就是connect。
import React, { Component } from 'react';
import { connect } from 'react-redux'; class TodoList extends Component{
  render() {
    return (
      <div>
        <div>
          <input value={this.props.inputValue} onChange = { this.props.changeInputValue}/>
          <button>提交</button>
        </div>
        <ul>
          <li></li>
        </ul>
      </div>
    )
  }
}
/**
* 这个意思是让TodoList这个组件和store进行连接。所以connect方法是做连接。
* 要连接就有连接的方式,所以第一个参数mapStateToProps
* 他的意思是TodoList与store做连接就有一个规则,规则在哪里,规则在mapStateToProps里面
*/
//mapStateToProps,把store里面的数据映射给这个组件,并变成组件的props. 而参数state就是指store里面的数据。
const mapStateToProps = (state) => {
  return {
    inputValue: state.inputValue
  }
} /***
* 我让Todolist这个组件跟store做关联,store里面的数据会映射到props上面
* 同时如果我想对store的数据做修改,也可以通过store的props来做修改
* mapDispatchToProps,dispatch,派发,把store的dispatch方法挂载到props上
*
*/
const mapDispatchToProps = (dispatch) => {
  return {
    changeInputValue(e){
      const action = {
        type: 'change_input_value',
        value: e.target.value
      }
      dispatch(action);
    }
  }
}
export default connect(mapStateToProps, mapDispatchToProps)(TodoList);

最新文章

  1. flddler使用方法
  2. Html注册表单示例
  3. [转]SQL:JOIN用法
  4. PHP包含文件函数include、include_once、require、require_once区别总结
  5. Tempdb对SQL Server性能的影响
  6. CAEmitterLayer实现粒子效果
  7. LeetCode_Convert Sorted List to Binary Search Tree
  8. git:fatal the current branch master has no upstream branch
  9. ASP.NET - 使用 XML
  10. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(19)-用户信息的修改和浏览
  11. 编译TensorFlow源码
  12. FC经典游戏还原之:松鼠大作战2
  13. table 表格的增删和修改
  14. SpriteBuilder中如何平均拉伸精灵帧动画的距离
  15. Mybatis 事务管理
  16. Linux编程 4 (创建文件touch,复制文件cp,tab补全,链接文件ln)
  17. thymeleaf给bootstrap自定义变量赋值
  18. day20-正则表达式练习
  19. oracle中case...when的用法
  20. 极大既然估计和高斯分布推导最小二乘、LASSO、Ridge回归

热门文章

  1. maven入门与常用插件使用
  2. nginx优化项目
  3. GreenPlum 大数据平台--外部表(三)
  4. djang4o查询某个字段的值
  5. TOJ 3486 Divisibility
  6. Unity3D之OnGUI知识总结
  7. java如何实现python的urllib.quote(str,safe=&#39;/&#39;)
  8. swpuctf-web部分学习总结
  9. Javascript “等于”
  10. JavaScript实现StringBuffer