详解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利用初始化数据装配模版的实现代码
Nov 17 Javascript
两个Javascript小tip资料
Nov 23 Javascript
js当一个变量为函数时 应该注意的一点细节小结
Dec 29 Javascript
按Enter键触发事件的jquery方法实现代码
Feb 17 Javascript
checkbox选中与未选中判断示例
Aug 04 Javascript
JavaScript通过setTimeout实时显示当前时间的方法
Apr 16 Javascript
JavaScript 字符串常用操作小结(非常实用)
Nov 30 Javascript
微信小程序图片自适应支持多图实例详解
Jun 21 Javascript
webpack配置导致字体图标无法显示的解决方法
Mar 06 Javascript
vue-router路由懒加载的实现(解决vue项目首次加载慢)
Aug 28 Javascript
jQuery实现的图片点击放大缩小功能案例
Jan 02 jQuery
微信小程序实现滚动Tab选项卡
Nov 16 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 字符过滤类,用于过滤各类用户输入的数据
2009/05/27 PHP
php操作mysql数据库的基本类代码
2014/02/25 PHP
PHP错误和异长常处理总结
2014/03/06 PHP
Codeigniter检测表单post数据的方法
2015/03/21 PHP
jQuery 使用手册(七)
2009/09/23 Javascript
jQuery EasyUI API 中文文档 - Form表单
2011/10/06 Javascript
jquery星级插件、支持页面中多次使用
2012/03/25 Javascript
输入密码检测大写是否锁定js实现代码
2012/12/03 Javascript
JQuery实现简单验证码提示解决方案
2012/12/20 Javascript
选择器中含有空格在使用示例及注意事项
2013/07/31 Javascript
js下拉框二级关联菜单效果代码具体实现
2013/08/03 Javascript
排序算法的javascript实现与讲解(99js手记)
2014/09/28 Javascript
简介JavaScript中用于处理正切的Math.tan()方法
2015/06/15 Javascript
jQuery幻灯片带缩略图轮播效果代码分享
2015/08/17 Javascript
JavaScript为事件句柄绑定监听函数实例详解
2015/12/15 Javascript
Angularjs过滤器使用详解
2016/05/25 Javascript
由浅入深剖析Angular表单验证
2016/07/14 Javascript
原生js获取元素样式的简单方法
2016/08/06 Javascript
react-router4 嵌套路由的使用方法
2017/07/24 Javascript
JS实现仿微信支付弹窗功能
2018/06/25 Javascript
jQuery实现网页拼图游戏
2020/04/22 jQuery
24个解决实际问题的ES6代码片段(小结)
2020/02/02 Javascript
Python中获取对象信息的方法
2015/04/27 Python
Python编程之多态用法实例详解
2015/05/19 Python
Python的Django框架中的URL配置与松耦合
2015/07/15 Python
python matplotlib中文显示参数设置解析
2017/12/15 Python
用Python将mysql数据导出成json的方法
2018/08/21 Python
Django Rest framework认证组件详细用法
2019/07/25 Python
pytorch numpy list类型之间的相互转换实例
2019/08/18 Python
python实现简单的购物程序代码实例
2020/03/03 Python
亚洲领先的旅游体验市场:Voyagin
2019/11/23 全球购物
莫言诺贝尔获奖演讲稿
2014/05/21 职场文书
党员个人对照检查材料范文
2014/09/24 职场文书
2016年“世界环境日”校园广播稿
2015/12/18 职场文书
python元组打包和解包过程详解
2021/08/02 Python
剖析后OpLog订阅MongoDB的数据变更就没那么难了
2022/02/24 MongoDB