首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >等待DOM元素,然后使用react - Reactjs

等待DOM元素,然后使用react - Reactjs
EN

Stack Overflow用户
提问于 2020-08-21 16:47:41
回答 5查看 3.5K关注 0票数 2

您好,我有一个如下所示的类组件:

代码语言:javascript
复制
class SomeComponent extends Component {
    componentDidMount = () => {
       const divElement = document.getElementbyId('id'); // this element could take a few seconds to load
       if (props.something1 && props.something2) {
          ..do something with divElement's width
       }
    }
    render() {
      return ....
    }
}

我想等到加载了divElement,或者在加载divElement时触发一个事件,这样我以后就可以进行计算了。我尝试添加了setTimeout,但没有起作用

EN

Stack Overflow用户

发布于 2020-08-21 16:56:06

这是一个愚蠢的解决方案,但它完成了自己的工作:

代码语言:javascript
复制
const getElementByIdAsync = id => new Promise(resolve => {
  const getElement = () => {
    const element = document.getElementById(id);
    if(element) {
      resolve(element);
    } else {
      requestAnimationFrame(getElement);
    }
  };
  getElement();
});

要使用它:

代码语言:javascript
复制
componentDidMount = async () => {
  const divElement = await getElementByIdAsync('id');
  if (props.something1 && props.something2) {
    // ..do something with divElement's width
  }
}
票数 1
EN
查看全部 5 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63519548

复制
相关文章

相似问题

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