详解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脚本函数库 方便开发
Oct 13 Javascript
JQuery中判断一个元素下面是否有内容或者有某个标签的判断代码
Feb 02 Javascript
javascript操作表格排序实例分析
May 06 Javascript
使用JavaScript刷新网页的方法
Jun 04 Javascript
javascript 动态修改css样式方法汇总(四种方法)
Aug 27 Javascript
小巧强大的jquery layer弹窗弹层插件
Dec 06 Javascript
Bootstrap布局组件教程之Bootstrap下拉菜单
Jun 12 Javascript
Vue.js组件tree实现省市多级联动
Dec 02 Javascript
利用JS实现文字的聚合动画效果
Jan 22 Javascript
Angular实现一个简单的多选复选框的弹出框指令实例
Apr 25 Javascript
Javascript迭代、递推、穷举、递归常用算法实例讲解
Feb 01 Javascript
json解析大全 双引号、键值对不在一起的情况
Dec 06 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数组去重复数据示例
2014/02/25 PHP
Yii2简单实现给表单添加验证码的方法
2016/07/18 PHP
postfixadmin忘记密码后的修改密码方法详解
2016/07/20 PHP
js关于精确计算和数值格式化以及直接引js文件
2014/01/28 Javascript
关闭时刷新父窗口两种方法
2014/05/07 Javascript
jquery验证邮箱格式是否正确实例讲解
2015/11/16 Javascript
JQuery实现Ajax加载图片的方法
2015/12/24 Javascript
jQuery实现鼠标选文字发新浪微博的方法
2016/04/02 Javascript
第八篇Bootstrap下拉菜单实例代码
2016/06/21 Javascript
jQuery插件版本冲突的处理方法分析
2017/01/16 Javascript
Vue学习笔记进阶篇之单元素过度
2017/07/19 Javascript
VUE2 前端实现 静态二级省市联动选择select的示例
2018/02/09 Javascript
vue实现弹框遮罩点击其他区域弹框关闭及v-if与v-show的区别介绍
2018/09/29 Javascript
vue+axios+promise实际开发用法详解
2018/10/15 Javascript
JS highcharts实现动态曲线代码示例
2020/10/16 Javascript
Python多线程编程(四):使用Lock互斥锁
2015/04/05 Python
python使用PyGame绘制图像并保存为图片文件的方法
2015/04/24 Python
基于python的Tkinter实现一个简易计算器
2015/12/31 Python
python图片验证码生成代码
2016/07/02 Python
python http基本验证方法
2018/12/26 Python
python Selenium实现付费音乐批量下载的实现方法
2019/01/24 Python
Python 下载Bing壁纸的示例
2020/09/29 Python
Python colormap库的安装和使用详情
2020/10/06 Python
Flask-SocketIO服务端安装及使用代码示例
2020/11/26 Python
YSL Beauty加拿大官方商城:圣罗兰美妆加拿大
2017/05/15 全球购物
德国机车企业:FC-Moto
2017/10/27 全球购物
英国探险旅游专家:Explore
2018/12/20 全球购物
世界领先的豪华床上用品供应商之一:Bedeck Home
2019/03/18 全球购物
我未来的职业规划范文
2014/01/11 职场文书
酒店秘书求职信范文
2014/02/17 职场文书
应届毕业生求职信范文
2014/05/08 职场文书
承诺书样本
2014/08/30 职场文书
护士2014年终工作总结
2014/11/11 职场文书
优秀共产党员主要事迹材料
2015/11/05 职场文书
Mysql服务添加 iptables防火墙策略的方案
2021/04/29 MySQL
python爬取豆瓣电影TOP250数据
2021/05/23 Python