为了账号安全,请及时绑定邮箱和手机立即绑定

反应上下文提供者不更新Class.contextType

反应上下文提供者不更新Class.contextType

慕桂英4014372 2021-04-09 14:15:31
我的应用程序使用React Context Provider传递用户配置文件。在我的App组件中,我的状态定义为:interface IState {  authUser: any;  userProfile: IProfile;  roles: string[];}在我的componentDidMount方法中,我使用fetch调用了三个不同的API。然后,结果为相应的条目调用setState。我的应用程序的渲染部分是:<AuthenticationContext.Provider value={this.state}>        <BrowserRouter>          <div>            <Navigation />            <Switch>/* Other routes removed for brevity */              <Route exact={true} path={routes.HOME} component={Home} />            </Switch>            <Footer />          </div>        </BrowserRouter>      </AuthenticationContext.Provider>在Home组件中,我这样使用静态的Class.contextType条目:public static contextType = AuthenticationContext;public context!: React.ContextType<typeof AuthenticationContext>;然后,在componentDidMount方法中,我正在调用另一个带有this.context.userProfile对象中的条目的API。我添加了控制台日志语句来跟踪生命周期。当我重新加载页面时,得到以下信息:Calling /api/profiles/getAdminStatus/7J4OwwnmQ1fMhavSLeLkDkKe9Kl2Calling getProfile within AppCalling /api/profiles/7J4OwwnmQ1fMhavSLeLkDkKe9Kl2 within getProfileCalling /api/profiles/7J4OwwnmQ1fMhavSLeLkDkKe9Kl2 within getLookingForCalling loadProfilesCalling getFilterResults with Userid: Calling /api/searchAbout to setState in getProfile within App: UserId: 7J4OwwnmQ1fMhavSLeLkDkKe9Kl2getFilterResults显示一个空白的Userid条目。但是,如果我浏览到另一个页面,然后返回此页面,则会得到以下结果:Calling /api/profiles/7J4OwwnmQ1fMhavSLeLkDkKe9Kl2 within getLookingForCalling loadProfilesCalling getFilterResults with Userid: 7J4OwwnmQ1fMhavSLeLkDkKe9Kl2Calling /api/search根据这些消息,我确定问题是在加载Home组件之前没有返回获取当前用户的初始调用。但是,我不明白为什么setState发生时为什么不重新渲染组件。我在主页内容周围添加了Consumer Component,但这没有帮助。我想到了将结果列表和方法列表也推到Context的想法,这样我就可以避免使用静态contextType,但这对我来说似乎有点棘手。关于我可能做错了什么的任何想法???
查看完整描述

1 回答

?
忽然笑

TA贡献1806条经验 获得超5个赞

经过大量研究,看来处理此问题的正确方法是在Context对象中实际添加方法,这些方法会修改App内的状态(或包含Context.Provider对象的任何组件)。


查看完整回答
反对 回复 2021-04-29
  • 1 回答
  • 0 关注
  • 179 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信