6

版本:

  • 反应路由器 dom 4.1.1
  • 反应路由器-redux 5.0.0-alpha.4
  • 反应传单 1.1.3
  • 传单 1.0.3

重现步骤

我创建了一张传单地图。我在其中添加了一些标记。这些标记有弹出窗口。在每个弹出窗口中,我都想要一个<Link>

另外,如果它有帮助,这是我的路由配置:

ReactDOM.render(
  <Provider store={store}>
    <div>
      <AppContainer />
      <ConnectedRouter history={history}>
        <div>
          <MenuContainer />
          <Switch>
            <Route path='/:area/:sport/list' component={ListContainer} />
            <Route path='/:area/:sport/map' component={MapContainer} />
            <Route path='/:area/:sport/rasp' component={RaspContainer} />
            <Route path='/:shortcode/details' component={StationDetailsContainer} />
            <Redirect exact from='/' to='/wellington/paragliding/list' />
            <Route component={NoMatch} />
          </Switch>
        </div>
      </ConnectedRouter>
    </div>
  </Provider>,
  document.getElementById('root')
)

预期行为

当弹出窗口打开时,我可以看到我的链接并单击它。

实际行为

实际行为 无法看到链接。它不是生成的。

额外细节

在我的里面我<MapMode>使用<Map>传单。如果我在标签<Link>上方设置 a ,它就可以工作。<Map>只要我想在我的内部有一个链接<Map>,它就会以某种方式中断。这是我页面的 React 结构,<Popup>标签只包含nullJavascript 正在破坏: 反应结构

这是一个相当复杂的问题,所以请随时问我问题。谢谢。

4

3 回答 3

11

我尝试了 Tharaka 建议的解决方案,但它对我不起作用。看起来 react-leaflet 的 Popup 正在使用它自己的上下文,因此阻止了从更高级别传递的上下文。但是,受此解决方案的启发,我想出了另一个非常简单且基于组合原则的解决方案。

我创建了 RouterForwarder 组件

import React, { Component } from 'react'
import PropTypes from 'prop-types'

class RouterForwarder extends Component {
  getChildContext() {
    return this.props.context
  }

  render() {
    return <span>{this.props.children}</span>
  }
}

RouterForwarder.childContextTypes = {
  router: PropTypes.object.isRequired,
}

RouterForwarder.propTypes = {
  context: PropTypes.object.isRequired,
}

export default RouterForwarder

然后以下列方式在我的组件(呈现 Map、Marker、Popup 和 Link 的组件)中使用它:

import RouterForwarder from './RouterForwarder'

class MyComponent extends Component {

  render() {
    return (
    ...
      <Popup>
        <RouterForwarder context={this.context}>
          <Link to={'my destination'}>Go to My Destination</Link>
        </RouterForwarder>
      </Popup>
    ...)
  }
}

MyComponent.contextTypes = {
  router: PropTypes.object,
}
于 2017-07-17T11:54:53.570 回答
4

我不是 100% 确定这个答案。但无论如何我都会尝试,因为我认为至少它可以为将来尝试解决这个问题的任何人提供一些启示。

我在GitHub 存储库中从这个问题中得到了第一个提示。react-leaflet根据那个和你的错误,问题似乎是 Popup 无法访问routerfrom ,context因为context没有以它们呈现的方式传递到 Popup 中。因此,如果我们可以将上下文显式传递给 Popup,我们应该能够解决问题。

然后我找到了一种将上下文显式传递到此StackOverflow 答案中的组件的方法。有了这个,我认为你应该能够使用如下的 HoC(高阶组件)来解决你的问题。

这是向组件注入上下文的 HoC:

function withContext(WrappedComponent, context){

  class ContextProvider extends React.Component {
    getChildContext() {
      return context;
    }

    render() {
      return <WrappedComponent {...this.props} />
    }
  }

  ContextProvider.childContextTypes = {};
  Object.keys(context).forEach(key => {
    ContextProvider.childContextTypes[key] = React.PropTypes.any.isRequired; 
  });

  return ContextProvider;
}

假设您在一个名为 MapMaker 的组件中使用 Popup。然后你可以router像这样使用 HoC 将上下文注入到 Popup 中。

class MapMaker extends React.Component {

  //......

  // This make sure you have router in you this.context
  // Also you can add any other context that you need to pass into Popup
  static contextTypes = {
    router: React.PropTypes.object.isRequired
  }

  render(){

    const PopupWithContext = withContext(Popup, this.context);

    return (
      //..... your JSX before Popup
      <PopupWithContext/> // with your props
      //..... your JSX after Popup
    );
  }

}
于 2017-04-24T17:55:37.550 回答
-1

我的解决方案(这是一种解决方法,但效果很好,我认为没有缺点):

我通过使用(在 react router v3 with redux中)解决了

<a onClick={() => goTo(params)} />

goTo定义在

const mapDispatchToProps = (dispatch) => bindActionCreators({
  goTo(id) {
    return push(`/<url>/${id}`); // push from 'react-router-redux'
  },
}, dispatch);
于 2017-06-30T12:59:12.120 回答