react dva 的 connect 与 @connect

1 篇文章 0 订阅

https://dvajs.com/guide/introduce-class.html#connect-方法

connect的作用是将组件和models结合在一起。将models中的state绑定到组件的props中。并提供一些额外的功能,譬如dispatch

connect 的使用

【connect 方法返回的也是一个 React 组件,通常称为容器组件。因为它是原始 UI 组件的容器,即在外面包了一层 State。

connect 方法传入的第一个参数是 mapStateToProps 函数,该函数需要返回一个对象,用于建立 State 到 Props 的映射关系。】

简而言之,connect接收一个函数,返回一个函数。

第一个函数会注入全部的models,你需要返回一个新的对象,挑选该组件所需要的models。

export default connect(({ user, login, global = {}, loading }) => ({
    currentUser: user.currentUser,
    collapsed: global.collapsed,
    fetchingNotices: loading.effects['global/fetchNotices'],
    notices: global.notices
}))(BasicLayout);

// 简化版
export default connect( 
  ({ user, login, global = {}, loading }) => {
        return {
          currentUser: user.currentUser,
          collapsed: global.collapsed,
          fetchingNotices: loading.effects['global/fetchNotices'],
          notices: global.notices
        }
  }
)(BasicLayout);

@connect的使用

其实只是connect的装饰器、语法糖罢了。

// 将 model 和 component 串联起来
export default connect(({ user, login, global = {}, loading }) => ({
    currentUser: user.currentUser,
    collapsed: global.collapsed,
    fetchingNotices: loading.effects['global/fetchNotices'],
    notices: global.notices,
    menuData: login.menuData,         // by hzy
    redirectData: login.redirectData, // by hzy
}))(BasicLayout);


// 改为这样(export 的不再是connect,而是class组件本身)也是可以执行的,但要注意@connect必须放在export default class前面
// 将 model 和 component 串联起来
@connect(({ user, login, global = {}, loading }) => ({
  currentUser: user.currentUser,
  collapsed: global.collapsed,
  fetchingNotices: loading.effects['global/fetchNotices'],
  notices: global.notices,
  menuData: login.menuData,         // by hzy
  redirectData: login.redirectData, // by hzy
}))

export default class BasicLayout extends React.PureComponent { 
   // ...
}

转自:http://www.cnblogs.com/CyLee/p/9308604.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Dva是一个基于Redux、React、Redux-saga等技术的轻量级框架,用于简化React应用的开发。Dva提供了一些约定和API,可以帮助我们更快速地开发React应用。以下是在React中使用dva的简单步骤: 1. 创建一个基于dvaReact应用 使用dva-cli工具创建一个新的dva项目: ``` $ npm install dva-cli -g $ dva new myApp ``` 2. 引入dva和相关依赖 在src/index.js文件中引入dva和相关依赖: ```javascript import dva from 'dva'; import './index.css'; // 1. Initialize const app = dva(); // 2. Plugins // app.use({}); // 3. Model // app.model(require('./models/example').default); // 4. Router // app.router(require('./router').default); // 5. Start app.start('#root'); ``` 3. 编写dva model 在src/models/目录下创建一个新的model文件,例如user.js: ```javascript export default { namespace: 'user', state: { list: [], }, reducers: { save(state, { payload: { list } }) { return { ...state, list }; }, }, effects: { *fetch({ payload }, { call, put }) { const { data } = yield call(queryUsers); yield put({ type: 'save', payload: { list: data, }, }); }, }, }; ``` 这个model定义了一个namespace为'user'的model,包括了state、reducers和effects三个部分。其中reducers用于处理同步操作,effects用于处理异步操作。 4. 注册dva model 在src/index.js文件中注册刚才编写的model: ```javascript import dva from 'dva'; import './index.css'; import user from './models/user'; // 1. Initialize const app = dva(); // 2. Plugins // app.use({}); // 3. Model app.model(user); // 4. Router // app.router(require('./router').default); // 5. Start app.start('#root'); ``` 5. 使用dva connect连接组件和model 在需要使用model的组件中,使用dva提供的connect方法连接组件和model: ```javascript import { connect } from 'dva'; function Users({ dispatch, users }) { function handleClick() { dispatch({ type: 'user/fetch', }); } return ( <div> <h1>List of users</h1> <button onClick={handleClick}>Fetch users</button> <ul> {users.list.map((user, index) => ( <li key={index}>{user.name}</li> ))} </ul> </div> ); } export default connect(({ user }) => ({ users: user }))(Users); ``` 这个组件使用了connect方法连接了'user'命名空间下的state和dispatch到组件的props中。 6. 运行应用 使用npm start命令启动应用: ``` $ cd myApp $ npm start ``` 以上是在React中使用dva的简单步骤,具体使用可以参照dva官方文档和示例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值