详解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 相关文章推荐
屏蔽Flash右键信息的js代码
Jan 17 Javascript
关于JavaScript的with 语句的使用方法
May 09 Javascript
javascript实现复选框选中属性
Mar 25 Javascript
详谈LABJS按需动态加载js文件
May 07 Javascript
javascript常用正则表达式汇总
Jul 31 Javascript
微信小程序 刷新上拉下拉不会断详细介绍
May 11 Javascript
Angular.js实现获取验证码倒计时60秒按钮的简单方法
Oct 18 Javascript
angular2中使用第三方js库的实例
Feb 26 Javascript
Vue2.5通过json文件读取数据的方法
Feb 27 Javascript
JavaScript文本特效实例小结【3个示例】
Dec 22 Javascript
ES6的异步操作之promise用法和async函数的具体使用
Dec 06 Javascript
JS通过识别id、value值对checkbox设置选中状态
Feb 19 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一些公用函数的集合
2008/03/27 PHP
实用的PHP带公钥加密类分享(每次加密结果都不一样哦)
2014/08/20 PHP
php生成唯一的订单函数分享
2015/02/02 PHP
ThinkPHP框架表单验证操作方法
2017/07/19 PHP
laravel 事件/监听器实例代码
2019/04/12 PHP
在laravel中实现事务回滚的方法
2019/10/10 PHP
php设计模式之代理模式分析【星际争霸游戏案例】
2020/03/23 PHP
extjs 学习笔记(三) 最基本的grid
2009/10/15 Javascript
nullJavascript中创建对象的五种方法实例
2013/05/07 Javascript
js实现简单计算器
2015/11/22 Javascript
js控制li的隐藏和显示实例代码
2016/10/15 Javascript
angular源码学习第一篇 setupModuleLoader方法
2016/10/20 Javascript
Javascript 获取鼠标当前的位置实现方法
2016/10/27 Javascript
Vue.js组件tab实现选项卡切换
2020/03/23 Javascript
js实现可以点击收缩或张开的悬浮窗
2017/09/18 Javascript
如何安装控制器JavaScript生成插件详解
2018/10/21 Javascript
手把手教你使用TypeScript开发Node.js应用
2019/05/06 Javascript
Element实现表格分页数据选择+全选所有完善批量操作
2019/06/07 Javascript
ES6 Promise对象概念及用法实例详解
2019/10/15 Javascript
借助云开发实现小程序短信验证码的发送
2020/01/06 Javascript
[43:41]OG vs Newbee 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.21.mp4
2020/07/19 DOTA
Python中的字符串操作和编码Unicode详解
2017/01/18 Python
解读python logging模块的使用方法
2018/04/17 Python
Python+OpenCV图片局部区域像素值处理改进版详解
2019/01/23 Python
python 哈希表实现简单python字典代码实例
2019/09/27 Python
Python 格式化打印json数据方法(展开状态)
2020/02/27 Python
Python编程快速上手——正则表达式查找功能案例分析
2020/02/28 Python
BONIA官方网站:国际奢侈品牌和皮革专家
2016/11/27 全球购物
PHP高级工程师面试问题推荐
2013/01/18 面试题
大学生先进事迹材料
2014/02/16 职场文书
公职人员索取回扣检举信
2014/04/04 职场文书
个人优缺点总结
2015/02/28 职场文书
联谊活动总结范文
2015/05/09 职场文书
创业者如何撰写出一份打动投资人的商业计划书?
2019/07/02 职场文书
HTML中的表格元素介绍
2022/02/28 HTML / CSS
java实现web实时消息推送的七种方案
2022/07/23 Java/Android