详解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 相关文章推荐
利用WebBrowser彻底解决Web打印问题(包括后台打印)
Jun 22 Javascript
JavaScript Timer实现代码
Feb 17 Javascript
javascript 基础篇3 类,回调函数,内置对象,事件处理
Mar 14 Javascript
jQuery 菜单随滚条改为以定位方式(固定要浏览器顶部)
May 24 Javascript
jquery text()方法取标签中的文本
Jul 25 Javascript
jQuery实现简易的天天爱消除小游戏
Oct 16 Javascript
jQuery实现表格文本框淡入更改值后淡出效果
Sep 27 Javascript
微信小程序 高德地图SDK详解及简单实例(源码下载)
Jan 11 Javascript
JS简单实现父子窗口传值功能示例【未使用iframe框架】
Sep 20 Javascript
ES6中数组array新增方法实例总结
Nov 07 Javascript
jQuery AJAX应用实例总结
May 19 jQuery
JavaScript Window浏览器对象模型原理解析
May 30 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
利用curl抓取远程页面内容的示例代码
2013/07/23 PHP
php获取中文拼音首字母类和函数分享
2014/04/24 PHP
codeigniter上传图片不能正确识别图片类型问题解决方法
2014/07/25 PHP
php判断手机浏览还是web浏览,并执行相应的动作简单实例
2016/07/28 PHP
PHP高并发和大流量解决方案整理
2019/12/24 PHP
Google韩国首页图标动画效果
2007/08/26 Javascript
jQueryUI的Dialog的简单封装
2010/06/07 Javascript
JS+ACTIVEX实现网页选择本地目录路径对话框
2013/03/18 Javascript
JavaScript中的this关键字介绍与使用实例
2013/06/21 Javascript
JavaScript中“过于”犀利地for/in循环使用示例
2013/10/22 Javascript
ParseInt函数参数设置介绍
2014/01/02 Javascript
jQuery使用after()方法在元素后面添加多项内容的方法
2015/03/26 Javascript
如何用javascript计算文本框还能输入多少个字符
2015/07/29 Javascript
JS组件Bootstrap Table使用方法详解
2016/02/02 Javascript
bootstrap响应式表格实例详解
2017/05/15 Javascript
vue2.0 实现页面导航提示引导的方法
2018/03/13 Javascript
JavaScript设计模式之装饰者模式定义与应用示例
2018/07/25 Javascript
关于vue v-for循环解决img标签的src动态绑定问题
2018/09/18 Javascript
详解微信小程序文件下载--视频和图片
2019/04/24 Javascript
Layer UI表格列日期格式化及取消自动填充日期的实现方法
2020/05/10 Javascript
python查询sqlite数据表的方法
2015/05/08 Python
python多维数组切片方法
2018/04/13 Python
Python3爬取英雄联盟英雄皮肤大图实例代码
2018/11/14 Python
Python3从零开始搭建一个语音对话机器人的实现
2019/08/23 Python
python打印n位数“水仙花数”(实例代码)
2019/12/25 Python
python自动打开浏览器下载zip并提取内容写入excel
2021/01/04 Python
Python实现我的世界小游戏源代码
2021/03/02 Python
HTML5 b和i标记将被赋予真正的语义
2009/07/16 HTML / CSS
马来西亚网上购物:Youbeli
2018/03/30 全球购物
非功能性需求都包括哪些方面
2013/10/29 面试题
英文版餐饮业求职信
2013/10/18 职场文书
组织关系转移介绍信
2014/01/16 职场文书
人力资源总监工作说明
2014/03/03 职场文书
廉政教育的心得体会
2014/09/01 职场文书
客户付款通知书
2015/04/23 职场文书
公路施工安全责任书
2015/05/08 职场文书