javascript - react router 匹配路由組件后如何在組件中 dispatch action 一次?
問題描述
用到了 react, react-router 4.1.1, redux 3.7.0, react-redux 5.0.5
Route配置為 <Route path='/:id' component={ Datagrid }/>,其中 id 為 path 路徑,Datagrid 為一個(gè)展示數(shù)據(jù)表格的容器組件,主體內(nèi)容為antd的 Table 組件,其中 columns 和 dataSource 要求能根據(jù) path 切換,我想實(shí)現(xiàn)當(dāng)點(diǎn)擊 /user 時(shí)加載 user 的 columns 和 dataSource,當(dāng)點(diǎn)擊/odm 時(shí)加載 odm 的 columns 和 dataSource。
Datagrid 組件如下
import React, { Component } from ’react’import { Table, Button } from ’antd’import ’./index.less’import { fetchColumn } from ’../../actions/column’import { connect } from ’react-redux’import { withRouter } from ’react-router-dom’class Datagrid extends Component { render() { let id = this.props.match.params.id console.log(id) this.props.dispatch(fetchColumn(id)) return ( <p><Table columns={this.props.column}/> </p> ) }}const mapStateToProps = (state) => { return state}export default withRouter(connect(mapStateToProps)(Datagrid))
當(dāng)點(diǎn)擊 /user path 時(shí)確實(shí)可以加載 user 的 column,但是dispatch(fetchColumn(id))會(huì)無限循環(huán),如果把dispatch(fetchColumn(id))放在componentDidMount中,只會(huì)加載一次,當(dāng)點(diǎn)擊 /odm 時(shí) Datagrid 組件又不會(huì)重新渲染了,不知道該怎么搞。
問題解答
回答1:class Datagrid extends Component { //用于第一次掛載時(shí)請(qǐng)求 componentDidMount() { let id = this.props.match.params.id console.log(id) this.props.dispatch(fetchColumn(id)) } //當(dāng)props發(fā)生改變時(shí)請(qǐng)求 componentWillReceiveProps(nextProps) { let id = this.props.match.params.id console.log(id) if(this.props.match.params.id != nextProps.match.params.id) {this.props.dispatch(fetchColumn(nextProps.match.params.id)) } } render() { return ( <p><Table columns={this.props.column}/> </p> ) }}回答2:
當(dāng)點(diǎn)擊/odm 時(shí)加載 odm 的 columns 和 dataSource。
那就在點(diǎn)擊事件里 dispatch 唄。
說錯(cuò)了,試試 componentDidUpdate。
相關(guān)文章:
1. android - rxjava merge 返回Object對(duì)象數(shù)據(jù)如何緩存2. mysql 一個(gè)sql 返回多個(gè)總數(shù)3. java - 三位二進(jìn)制表示8進(jìn)制,四位二進(jìn)制表示16進(jìn)制,那么多少二進(jìn)制表示10進(jìn)制呢?4. 如何用筆記本上的apache做微信開發(fā)的服務(wù)器5. CSS3 畫如下圖形6. angular.js - ionic2 瀏覽器跨域問題7. javascript - 螞蟻金服里的react Modal方法,是怎么把元素插入到頁面最后的8. python - Scrapy存在內(nèi)存泄漏的問題。9. 【python|scapy】sprintf輸出時(shí)raw_string轉(zhuǎn)string10. docker 下面創(chuàng)建的IMAGE 他們的 ID 一樣?這個(gè)是怎么回事????
