首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >recompose withState如何更新道具变更

recompose withState如何更新道具变更
EN

Stack Overflow用户
提问于 2017-10-24 04:48:06
回答 2查看 5.7K关注 0票数 2

我有一个更高阶的组件,我试着修改一下(我不熟悉recompose)。

这就是我的组件:

代码语言:javascript
复制
<Map mycenter={mycenter}  />

如果mycenter被更新,我希望map-component更新或重新渲染。我正在尝试修改https://github.com/istarkov/google-map-thousands-markers/blob/master/src/Map.js中的代码

我对代码做了一些修改。首先,将地图中心设置为mycenter。这是可行的。

代码语言:javascript
复制
withState('mapParams', 'setMapParams', ({ mycenter }) => ({ center:mycenter, zoom: 12 })),

在此之后,用户可以单击某个位置,中心将被修改

代码语言:javascript
复制
withHandlers({
    onMapParamsChange: ({ setMapParams }) => ({ center, zoom, bounds }) => {
      setMapParams({ center, zoom, bounds });
      console.log('setMapParams', { center, zoom });
    },

有没有办法在"mycenter“更新的情况下重新渲染组件或更新中心?

EN

回答 2

Stack Overflow用户

发布于 2018-01-20 17:20:46

目前,最好的方式是使用lifecycle。初始状态(({ mycenter }) => ({ center:mycenter, zoom: 12 }))的回调只发生一次。

代码语言:javascript
复制
const enhanceMap = compose(
  withState('mapParams', 'setMapParams', ({ mycenter }) => ({ center: mycenter, zoom: 12 })),
  withStateHandlers({...}),
  lifecycle({
    componentWillUpdate(nextProps) {
      if (this.props.mycenter !== nextProps.mycenter)
        this.setState({mapParams: { center: nextProps.mycenter, zoom: 12 }})
    }
  })
)
票数 4
EN

Stack Overflow用户

发布于 2018-06-14 03:38:22

希望这不要来得太晚。

我发现将道具转换为状态有点混乱..

现在,recompose允许您将函数作为withProps方法的参数发送。你可以这样做:

代码语言:javascript
复制
withProps( props => ({
  mycenter: props.mycenter,
  zoom: 12,
}))

这样,你就可以将你的道具向下传播到你的组件,当道具发生变化时,它就会更新。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46898253

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档