React-Router-Dom重定向问题

时间:2019-02-04 14:59:25

标签: javascript reactjs react-redux react-router-dom

我正在执行的是youtube的实现的这个项目,比方说,我在“ /”搜索“ Sia”,然后通过视频,频道,播放列表返回结果,而当我点击频道项目时,现在使用channel组件路由到“ / channel”,问题是,当我在/ channel中搜索内容时,我应该重定向回“ /”并使用提交的搜索词获得搜索结果。但是我不知道出了什么问题,或者是否可以将Header组件作为BrowserRouter的直接子代,或者将它连同它的props一起呈现在每个路由组件中(无论如何我都打算这样做) 这是频道组件和路由

class ChannelDisplay extends React.Component {
onFormSubmit = (term) => {
    this.props.fetchList(term);
    this.props.defaultVideo(term);
}

renderHeader() {
    const {channel} = this.props
    if(!channel.snippet) return <Search/>
    if(channel) {
        const subNum = `${Number(channel.statistics.subscriberCount).toLocaleString()}`
        return (
            <div className="channel">
                <Header onFormSubmit={this.onFormSubmit}/>
                <div className="container">
                    <img className="img-fluid" src={channel.brandingSettings.image.bannerImageUrl} alt={channel.snippet.title} />
                    <div className="d-flex flex-nowrap">
                            <img className="img-thumbnail img-fluid channel-img mx-2 my-2" src={channel.snippet.thumbnails.default.url} alt={channel.snippet.title} />
                        <div className="media-content">
                            <p>{channel.snippet.title}</p>
                            <span><i className="fab fa-youtube mr-2"></i> Subscribe {subNum}</span>
                        </div>
                    </div>
                </div>
            </div>
        )
    }
}

render() {
    return this.renderHeader()   
 }
}

const mapStateToProps = state => {
    return {channel:state.channel}
}

export default connect(mapStateToProps,{fetchList,defaultVideo}) 
(ChannelDisplay)

render() {
    return (
        <div>
            <BrowserRouter>
                <div>
                    <Route path="" exact component={Search} />
                    <Route path="/channel" exact component={ChannelDisplay} />
                </div>
            </BrowserRouter>
        </div>
    )
}

整个代码https://github.com/IslamGamal88/minitube

1 个答案:

答案 0 :(得分:1)

也许您应该将history.pushhistory.replace添加到Search.js文件的提交函数中,但是我认为推送是一个更好的选择,因为您可以返回{ {1}}到您的频道或视频或其他内容。

back button