详解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 相关文章推荐
javascript offsetX与layerX区别
Mar 12 Javascript
说明你的Javascript技术很烂的五个原因
Apr 26 Javascript
也说JavaScript中String类的replace函数
Sep 22 Javascript
探讨JQUERY JSON的反序列化类 using问题的解决方法
Dec 19 Javascript
jquery移除、绑定、触发元素事件使用示例详解
Apr 10 Javascript
函数window.open实现关闭所有的子窗口
Aug 03 Javascript
javascript针对不确定函数的执行方法
Dec 16 Javascript
jQuery解析XML 详解及方法总结
Sep 28 Javascript
微信小程序 教程之wxapp 视图容器 view
Oct 19 Javascript
Vue组件之单向数据流的解决方法
Nov 10 Javascript
浅谈小程序 setData学问多
Feb 20 Javascript
解决vuex刷新数据消失问题
Nov 12 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
关于Zend Studio 配色方案插件的介绍
2013/06/24 PHP
php对数组排序代码分享
2014/02/24 PHP
php简单操作mysql数据库的类
2015/04/16 PHP
php实现的中文分词类完整实例
2017/02/06 PHP
在IE上直接编辑网页内容的js代码(IE地址栏js)
2009/04/27 Javascript
IE6/7 and IE8/9/10(IE7模式)依次隐藏具有absolute或relative的父元素和子元素后再显示父元素
2011/07/31 Javascript
jQuery获取URL请求参数的方法
2015/07/18 Javascript
逐一介绍Jquery data()、Jquery stop()、jquery delay()函数(详)
2015/11/04 Javascript
Bootstrap弹出带合法性检查的登录框实例代码【推荐】
2016/06/23 Javascript
基于bootstrap实现广告轮播带图片和文字效果
2016/07/22 Javascript
EditPlus中的正则表达式 实战(2)
2016/12/15 Javascript
微信小程序 页面传值详解
2017/03/10 Javascript
JavaScript键盘事件响应顺序详解
2019/09/30 Javascript
vue elementUI 表单校验的实现代码(多层嵌套)
2019/11/06 Javascript
Vue组件化开发之通用型弹出框的实现
2020/02/28 Javascript
extjs4图表绘制之折线图实现方法分析
2020/03/06 Javascript
使用JavaScript和MQTT开发物联网应用示例解析
2020/08/07 Javascript
js实现右键弹出自定义菜单
2020/09/08 Javascript
Nodejs实现微信分账的示例代码
2021/01/19 NodeJs
python动态性强类型用法实例
2015/05/09 Python
Python带动态参数功能的sqlite工具类
2018/05/26 Python
pycharm下查看python的变量类型和变量内容的方法
2018/06/26 Python
Python如何使用Gitlab API实现批量的合并分支
2019/11/27 Python
python matplotlib工具栏源码探析二之添加、删除内置工具项的案例
2021/02/25 Python
Html5实现二维码扫描并解析
2016/01/20 HTML / CSS
如何提高MySql的安全性
2014/06/19 面试题
群众路线批评与自我批评
2014/02/06 职场文书
敬老模范事迹
2014/05/21 职场文书
班组长安全工作职责
2014/07/15 职场文书
应届大学生求职信
2014/07/20 职场文书
运动会加油稿100字
2014/09/19 职场文书
公民代理授权委托书
2014/09/24 职场文书
教师见习总结范文
2015/06/23 职场文书
小学英语教师研修感悟
2015/11/18 职场文书
2016领导干部廉洁自律心得体会
2016/01/13 职场文书
苹果可能正在打击不进行更新的 App
2022/04/24 数码科技