首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Bootstrap模式,react-resize-observer返回空值

使用Bootstrap模式,react-resize-observer返回空值
EN

Stack Overflow用户
提问于 2020-11-13 21:56:06
回答 1查看 111关注 0票数 0

我正在尝试使用react-resize-observer来检测容器大小的变化。为此,我在我的自定义组件中嵌入了一个ResizeObserver

当组件被隔离使用时,它工作得很好。但是,一旦在Bootstrap模式中使用它(从react-bootstrap),就会使用空值(width === height === 0)调用ResizeObserveronResize回调。

我做错了什么?

EN

回答 1

Stack Overflow用户

发布于 2020-11-13 21:56:06

问题来自于模式的显示方式:使用动画。当第一次呈现模态组件时,它是隐藏的,因此react-resize-observer报告空值。

即时修复

关闭动画:

代码语言:javascript
复制
<Modal
  animation={false}
>

至少,你应该试一试,确保它能解决这个问题。

使react-resize-observer在保持动画效果的同时工作

诀窍是只有在模式动画实际启动时才开始显示ResizeObserver及其父组件,这要归功于onEntering回调:

代码语言:javascript
复制
export const MyModal = () => {
  const [ showComponent, setShowComponent ] = useState(false);

  return (
    <Modal
      onEntering={() => setShowComponent(true)}
    >
      {showComponent && (
        <div>
          <ResizeObserver onResize={(rect) => {...}}/>
          ...
        </div>
      )}
    </Modal>
  );
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64822182

复制
相关文章

相似问题

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