详解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 相关文章推荐
safari,opera嵌入iframe页面cookie读取问题解决方法
Jun 23 Javascript
javascript中万恶的function实例分析
May 25 Javascript
js window.open弹出新的网页窗口
Jan 16 Javascript
jquery实现具有嵌套功能的选项卡
Feb 12 Javascript
JS实现图片高斯模糊切换效果的焦点图实例
Jan 21 Javascript
javascript 动态生成css代码的两种方法
Mar 17 Javascript
JavaScript实现简单的四则运算计算器完整实例
Apr 28 Javascript
vue-router 导航钩子的具体使用方法
Aug 31 Javascript
Vue.js实现的计算器功能完整示例
Jul 11 Javascript
JS代码触发事件代码实例
Jan 02 Javascript
js实现搜索提示框效果
Sep 05 Javascript
TypeScript中条件类型精读与实践记录
Oct 05 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文件缓存类用法实例分析
2015/04/22 PHP
Symfony控制层深入详解
2016/03/17 PHP
PHP 与 UTF-8 的最佳实践详细介绍
2017/01/04 PHP
php实现文件预览功能
2017/05/23 PHP
laravel中短信发送验证码的实现方法
2018/04/25 PHP
JavaScript iframe的相互操作浅析
2009/10/14 Javascript
IE8 chrome中table隔行换色解决办法
2010/07/09 Javascript
一次失败的jQuery优化尝试小结
2011/02/06 Javascript
javascript打开word文档的方法
2014/04/16 Javascript
js实现飞入星星特效代码
2014/10/17 Javascript
javascript实现自动输出文本(打字特效)
2015/08/27 Javascript
BootStrap3中模态对话框的使用
2017/01/06 Javascript
js实现用户输入的小写字母自动转大写字母的方法
2017/01/21 Javascript
JS库之Highlight.js的用法详解
2017/09/13 Javascript
vue中父子组件注意事项,传值及slot应用技巧
2018/05/09 Javascript
微信小程序功能之全屏滚动效果的实现代码
2018/11/22 Javascript
json数据格式常见操作示例
2019/06/13 Javascript
vue中v-model对select的绑定操作
2020/08/31 Javascript
如何在 ant 的table中实现图片的渲染操作
2020/10/28 Javascript
python实现连接mongodb的方法
2015/05/08 Python
Python3处理HTTP请求的实例
2018/05/10 Python
python OpenCV GrabCut使用实例解析
2019/11/11 Python
python实现简易版学生成绩管理系统
2020/06/22 Python
Python实现Excel自动分组合并单元格
2021/02/22 Python
YSL圣罗兰美妆英国官网:Yves Saint Laurent Beauty UK
2019/08/03 全球购物
Haggar官网:美国男装品牌
2020/02/16 全球购物
武汉高蓝德国际.net机试
2016/06/24 面试题
函授毕业生自我鉴定
2013/11/06 职场文书
产品销售员岗位职责
2013/12/18 职场文书
白莲教口号
2014/06/18 职场文书
合唱兴趣小组活动总结
2014/07/10 职场文书
城管执法人员个人对照检查材料思想汇报
2014/09/29 职场文书
2016圣诞节贺卡寄语
2015/12/07 职场文书
Go语言切片前或中间插入项与内置copy()函数详解
2021/04/27 Golang
Mysql systemctl start mysqld报错的问题解决
2021/06/03 MySQL
Java各种比较对象的方式的对比总结
2021/06/20 Java/Android