详解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 相关文章推荐
实用的JS正则表达式(手机号码/IP正则/邮编正则/电话等)
Jan 11 Javascript
jQuery的3种请求方式$.post,$.get,$.getJSON
Mar 28 Javascript
jquery通过visible来判断标签是否显示或隐藏
May 08 Javascript
jquery 取子节点及当前节点属性值的方法
Aug 24 Javascript
JQuery包裹DOM节点的方法
Jun 11 Javascript
单击按钮发送验证码,出现倒计时的简单实例
Mar 17 Javascript
Vue自定义指令使用方法详解
Aug 21 Javascript
JavaScript 九种跨域方式实现原理
Feb 11 Javascript
vue component 中引入less文件报错 Module build failed
Apr 17 Javascript
基于JavaScript实现表格隔行换色
May 08 Javascript
JavaScript原始值与包装对象的详细介绍
May 11 Javascript
JavaScript高级程序设计之基本引用类型
Nov 17 Javascript
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
PHP中几种常见的超时处理全面总结
2012/09/11 PHP
PHP中$_FILES的使用方法及注意事项说明
2014/02/14 PHP
php提示Failed to write session data错误的解决方法
2014/12/17 PHP
PHP实现mysqli批量执行多条语句的方法示例
2017/07/22 PHP
jQuery 表单验证插件formValidation实现个性化错误提示
2009/06/23 Javascript
实现变速回到顶部的JavaScript代码
2011/05/09 Javascript
jquery动态加载js/css文件方法(自写小函数)
2014/10/11 Javascript
jquery增加和删除元素的方法
2015/01/14 Javascript
avalonjs制作响应式瀑布流特效
2015/05/06 Javascript
跟我学习javascript的严格模式
2015/11/16 Javascript
Node.js与MySQL交互操作及其注意事项
2016/10/05 Javascript
js实现table添加行tr、删除行tr、清空行tr的简单实例
2016/10/15 Javascript
微信小程序 实现拖拽事件监听实例详解
2016/11/16 Javascript
Javascript之面向对象--接口
2016/12/02 Javascript
jQuery插件FusionCharts绘制2D双折线图效果示例【附demo源码】
2017/04/14 jQuery
JavaScript实现简单音乐播放器
2020/04/17 Javascript
vue实现菜单切换功能
2019/05/08 Javascript
Python实现批量下载图片的方法
2015/07/08 Python
Python利用递归和walk()遍历目录文件的方法示例
2017/07/14 Python
使用python和Django完成博客数据库的迁移方法
2018/01/05 Python
对Python中gensim库word2vec的使用详解
2018/05/08 Python
TensorFlow打印输出tensor的值
2020/04/19 Python
python函数map()和partial()的知识点总结
2020/05/26 Python
keras和tensorflow使用fit_generator 批次训练操作
2020/07/03 Python
Python2手动安装更新pip过程实例解析
2020/07/16 Python
巴西最大的在线约会网站:ParPerfeito
2018/07/11 全球购物
汽车技术服务英文求职信范文
2014/01/02 职场文书
高中学生评语大全
2014/04/25 职场文书
实习单位证明范例
2014/11/17 职场文书
时尚女魔头观后感
2015/06/04 职场文书
丧事答谢词大全
2015/09/30 职场文书
python 实现mysql自动增删分区的方法
2021/04/01 Python
MySQL命令行操作时的编码问题详解
2021/04/14 MySQL
Python爬虫实战之爬取携程评论
2021/06/02 Python
Pytorch distributed 多卡并行载入模型操作
2021/06/05 Python
利用python调用摄像头的实例分析
2021/06/07 Python