Redux的 connect 与 @connect

本文详细介绍了React-Redux中connect函数的作用及使用方法,包括如何将store数据映射到组件props,以及如何处理dispatch操作。通过实例展示了mapStateToProps和mapDispatchToProps的用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

connect

connect函数的主要作用就是将store中的数据传递到props中。在组件中使用connect后就可以在this.props中访问到store中的数据了。

例子如下:

//MyApp.jsx
import React from 'react';
import action from ‘action’
import { connect } from 'react-redux';

function mapStateToProps(state) {
  return { todos: state.todos };
}

function mapDispatchToProps(dispatch) {
  return { actions: action();
}

class MyApp extends React.Component {

}

export default connect(mapStateToProps, mapDispatchToProps)(MyApp);

connect()函数的参数为:

connect([mapStateToProps], [mapDispatchToProps], [mergeProps], [options])

其中后两个参数一般被忽略。

  • [mapStateToProps]是一个函数,返回值必须为一个纯对象,这个对象会被合并到组件的props中。当Redux store发生变化时,mapStateToProps就会被调用。
  • [mapDispatchToProps]一般是一个对象(或者是一个函数,函数的返回值为对象),对象的值是函数,当这些函数执行时,返回值会被合并到组件的props中。

 

@connect

@称为 装饰器(Decorator),是ES6中的语法,主要用来注释或修改类和类方法。

装饰器是一种函数,写成@ + 函数名。它可以放在类和类方法的定义前面

使用装饰器之后:

//MyApp.jsx
import React from 'react';
import action from ‘action’
import { connect } from 'react-redux';

function mapStateToProps(state) {
  return { todos: state.todos };
}

function mapDispatchToProps(dispatch) {
  return { actions: action();
}

@connect(mapStateToProps, mapDispatchToProps)
export default class MyApp extends React.Component {
  
}

在使用了@之后就不需要在connect()(MyApp)后再加一个参数:组件名(MyApp)了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值