详解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中的不可见数据类型
Dec 02 Javascript
node.js中的fs.createReadStream方法使用说明
Dec 17 Javascript
jQuery中append()方法用法实例
Dec 25 Javascript
js判断登录与否并确定跳转页面的方法
Jan 30 Javascript
JavaScript算法教程之sku(库存量单位)详解
Jun 29 Javascript
JS实现问卷星自动填问卷脚本并在两秒自动提交功能
Jun 17 Javascript
vue购物车插件编写代码
Nov 27 Javascript
浅析node应用的timing-attack安全漏洞
Feb 28 Javascript
Angularjs Promise实例详解
Mar 15 Javascript
vue项目中,main.js,App.vue,index.html的调用方法
Sep 20 Javascript
vue引入微信sdk 实现分享朋友圈获取地理位置功能
Jul 04 Javascript
javascript递归函数定义和用法示例分析
Jul 22 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
如何限制访问者的ip(PHPBB的代码)
2006/10/09 PHP
服务器端解压缩zip的脚本
2006/12/22 PHP
php下实现伪 url 的超简单方法[转]
2007/09/24 PHP
简单的PHP留言本实例代码
2010/05/09 PHP
利用php+mcDropdown实现文件路径可在下拉框选择
2013/08/07 PHP
PHP中soap的用法实例
2014/10/24 PHP
location.href语句与火狐不兼容的问题
2010/07/04 Javascript
用jQuery模拟select下拉框的简单示例代码
2014/01/26 Javascript
鼠标移到图片上变大显示而不是放大镜效果
2014/06/15 Javascript
js事件监听机制(事件捕获)总结
2014/08/08 Javascript
js中confirm实现执行操作前弹出确认框的方法
2014/11/01 Javascript
node.js中的fs.renameSync方法使用说明
2014/12/16 Javascript
Bootstrap项目实战之首页内容介绍(全)
2016/04/25 Javascript
JS 数字转换为大写金额的简单实例
2016/08/04 Javascript
Angular.JS判断复选框checkbox是否选中并实时显示
2016/11/30 Javascript
React中jquery引用的实现方法
2017/09/12 jQuery
Bootstrap的aria-label和aria-labelledby属性实例详解
2018/11/02 Javascript
JS document内容及样式操作完整示例
2020/01/14 Javascript
bootstrap-closable-tab可实现关闭的tab标签页插件
2020/08/09 Javascript
前端性能优化建议
2020/09/17 Javascript
python中bisect模块用法实例
2014/09/25 Python
matplotlib在python上绘制3D散点图实例详解
2017/12/09 Python
python调用虹软2.0第三版的具体使用
2019/02/22 Python
python模拟点击网页按钮实现方法
2020/02/25 Python
四方通行旅游网:台湾订房、出国旅游
2017/09/20 全球购物
美国购买舞会礼服网站:Couture Candy
2019/12/29 全球购物
结婚喜宴主持词
2014/03/14 职场文书
反邪教警示教育方案
2014/05/13 职场文书
旅游饭店管理专业自荐书
2014/06/28 职场文书
高中运动会广播稿
2014/09/16 职场文书
学术会议通知范文
2015/04/15 职场文书
奖励申请报告范文
2015/05/15 职场文书
负责培养人意见
2015/06/05 职场文书
python 提取html文本的方法
2021/05/20 Python
sql中mod()函数取余数的用法
2021/05/29 SQL Server
MySQL中JOIN连接的基本用法实例
2022/06/05 MySQL