详解react-redux插件入门


Posted in Javascript onApril 19, 2018

可先查看我的redux简单入门

react-redux简介

react-redux是使用redux开发react时使用的一个插件,另外插一句,redux不是react的产品,vue和angular中也可以使用redux;下面简单讲解,如何使用react-redux来开发react。

描述

这个插件可以让我们的redux代码更加的简洁和美观。我假设你已经有一个使用create-react-app创建的一个可以显示hello world的react环境,并且已经安装来redux。

注意:如果是刚使用create-react-app创建的,需要运行 npm run eject弹出个性化设置,这样就可以自定义配置了。

安装

npm i react-redux --save

使用

react-redux提供了两个重要的接口:Provider、connect,使用了这个插件,react-redux的subscribe和dispatch就可以忘记来,它们就用不着了。

代码结构

//index.js

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import registerServiceWorker from './registerServiceWorker';
import { createStore, applyMiddleware } from 'redux';
import thunk from 'redux-thunk';
import { reducer } from './index.redux';
import { Provider } from 'react-redux'

const store = createStore(reducer, applyMiddleware(thunk));

ReactDOM.render(
  <Provider store={store}>
    <App />
  </Provider>,
  document.getElementById('root')
);

registerServiceWorker();

Provider中应用的最外层,把store传给它,只使用这一次。

//app.js

import React, { Component } from 'react';
import { addCreator, removeCreator, addAsync } from './index.redux';
import { connect } from 'react-redux';
class App extends Component {
 render() {
  return (
   <div className="App">
    <h1>现在有美女{this.props.num}个。</h1>
    <button onClick={this.props.addCreator}>add</button>
    <button onClick={this.props.removeCreator}>remove</button>
    <button onClick={this.props.addAsync}>addAsync</button>
   </div >
  );
 }
}

//定义把state中哪个属性放到props中
 function mapStateToProps(state) {
  return { num: state }
 }
 //定义把哪些方法放到props中
 const actionCreators={ addCreator, removeCreator, addAsync };
 //connect其实就是一个高阶组件,把app传进去,返回一个新的app组件
 App = connect(mapStateToProps, actionCreators)(App);
export default App;

connect负责从外部获取组件需要的参数。通过connect定义后,放到props中的属性和方法就可以直接通过this.props来获取。

下面是reducer的定义。

//react.redux.js

const Add = 'addGirl', Remove = "removeGirl";

export function reducer(state = 0, action) {
  switch (action.type) {
    case Add:
      return state + 1;
    case Remove:
      return state - 1;
    default:
      return 10;
  }
}

export function addCreator() {
  return { type: Add };
}
export function removeCreator() {
  return { type: Remove };
}

export function addAsync() {
  return (dispatch, getState) => {
    setTimeout(function () {
      dispatch(addCreator());
    }, 1000);
  }
}

使用装饰器的方式更优雅的写Conect

首先需要安装babel-plugin-transform-decorators-legacy,并在package.json中配置。

安装

npm i babel-plugin-transform-decorators-legacy --save-dev 这个只是开发使用,所以安装到--save-dev

配置

配置babel的plugins属性

"babel": {
  "presets": [
   "react-app"
  ],
  "plugins": [
   ["transform-decorators-legacy"]
  ]
 }

修改原来写法
使用@connect来重新定义,写到class的上头即可。

//App.js

@connect((state) => ({ num: state }),{ addCreator, removeCreator, addAsync })
class App extends Component {
.....//省略


// function mapStateToProps(state) {
//  return { num: state }
// }
// App = connect(mapStateToProps, { addCreator, removeCreator, addAsync })(App);

VS Code 装饰器提示“experimentalDecorators”的解决办法

点击Visual Studio Code左下角的配置按钮(或者文件>首选项>配置,Windows环境),打开用户设置窗口,在搜索框内输入“experimentalDecorators”,发现竟然能够找到选项,如下:

"javascript.implicitProjectConfig.experimentalDecorators": false

改成true就可以了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Firefox 无法获取cssRules 的解决办法
Oct 11 Javascript
javascript检测对象中是否存在某个属性判断方法小结
May 19 Javascript
jQuery实现三级菜单的代码
May 09 Javascript
详解微信小程序开发之下拉刷新 上拉加载
Nov 24 Javascript
JavaScript中for循环的几种写法与效率总结
Feb 03 Javascript
jQuery用户头像裁剪插件cropbox.js使用详解
Jun 07 jQuery
Node.js 使用命令行工具检查更新
Jun 08 Javascript
使用 jQuery 实现表单验证功能
Jul 05 jQuery
Vue-路由导航菜单栏的高亮设置方法
Mar 17 Javascript
Bootstrap table 实现树形表格联动选中联动取消功能
Sep 30 Javascript
Openlayers实现图形绘制
Sep 28 Javascript
Vue组件化(ref,props, mixin,.插件)详解
May 15 Vue.js
vuex state及mapState的基础用法详解
Apr 19 #Javascript
使用vuex的state状态对象的5种方式
Apr 19 #Javascript
react redux入门示例
Apr 19 #Javascript
JS实现读取xml内容并输出到div中的方法示例
Apr 19 #Javascript
使用typescript开发angular模块并发布npm包
Apr 19 #Javascript
Angular 封装并发布组件的方法示例
Apr 19 #Javascript
angular第三方包开发整理(小结)
Apr 19 #Javascript
You might like
解决phpmyadmin 乱码,支持gb2312和utf-8
2006/11/20 PHP
在wamp集成环境下升级php版本(实现方法)
2013/07/01 PHP
PHP实现利用MySQL保存session的方法
2014/08/23 PHP
PHP中实现获取IP和地理位置类分享
2015/02/10 PHP
如何通过View::first使用Laravel Blade的动态模板详解
2017/09/21 PHP
PHP设计模式之观察者模式定义与用法示例
2018/08/04 PHP
js原型链原理看图说明
2012/07/07 Javascript
JS实现div内部的文字或图片自动循环滚动代码
2013/04/19 Javascript
jquery easyui使用心得
2014/07/07 Javascript
再谈javascript原型继承
2014/11/10 Javascript
javascript实现的多个层切换效果通用函数实例
2015/07/06 Javascript
JS实现响应鼠标点击动画渐变弹出层效果代码
2016/03/25 Javascript
js html5 css俄罗斯方块游戏再现
2016/10/17 Javascript
基于LayUI实现前端分页功能的方法
2017/07/22 Javascript
随机生成10个不重复的0-100的数字(实例讲解)
2017/08/16 Javascript
Node.JS使用Sequelize操作MySQL的示例代码
2017/10/09 Javascript
angular2中Http请求原理与用法详解
2018/01/11 Javascript
vuedraggable+element ui实现页面控件拖拽排序效果
2020/07/29 Javascript
JavaScript格式化json和xml的方法示例
2019/01/22 Javascript
vue实现axios图片上传功能
2019/08/20 Javascript
解决vue项目中出现Invalid Host header的问题
2020/11/17 Javascript
Python3 单行多行万能正则匹配方法
2019/01/07 Python
python画双y轴图像的示例代码
2019/07/07 Python
python 并发下载器实现方法示例
2019/11/22 Python
用python爬取历史天气数据的方法示例
2019/12/30 Python
python 解决tqdm模块不能单行显示的问题
2020/02/19 Python
python使用for...else跳出双层嵌套循环的方法实例
2020/05/17 Python
名词解释型面试题(主要是网络)
2013/12/27 面试题
服务生自我鉴定
2014/01/22 职场文书
房屋买卖委托公证书
2014/04/08 职场文书
工厂车间标语
2014/06/19 职场文书
生物学专业求职信
2014/07/23 职场文书
试用期解除劳动合同通知书
2015/04/16 职场文书
关于教师节的广播稿
2015/08/19 职场文书
高中运动会广播稿
2015/08/19 职场文书
配置nginx 重定向到系统维护页面
2021/06/08 Servers