react hook: useLayoutEffect

useLayoutEffect 可能会影响性能。尽可能使用 useEffect。(由于 useLayoutEffect 它会在浏览器更新布局之前同步执行。 在执行时会阻塞浏览器更新,因此需要谨慎使用)

useLayoutEffect 是 useEffect 的一个版本,在浏览器重新绘制屏幕之前触发。

在浏览器重新绘制屏幕前计算布局
大多数组件不需要依靠它们在屏幕上的位置和大小来决定渲染什么。他们只返回一些 JSX,然后浏览器计算他们的 布局(位置和大小)并重新绘制屏幕。

有时候,这还不够。想象一下悬停时出现在某个元素旁边的 tooltip。如果有足够的空间,tooltip 应该出现在元素的上方,但是如果不合适,它应该出现在下面。为了让 tooltip 渲染在最终正确的位置,你需要知道它的高度(即它是否适合放在顶部)。

要做到这一点,你需要分两步渲染:

将 tooltip 渲染到任何地方(即使位置不对)。
测量它的高度并决定放置 tooltip 的位置。
把 tooltip 渲染放在正确的位置。
所有这些都需要在浏览器重新绘制屏幕之前完成。你不希望用户看到 tooltip 在移动。调用 useLayoutEffect 在浏览器重新绘制屏幕之前执行布局测量:

function Tooltip() {
  const ref = useRef(null);
  const [tooltipHeight, setTooltipHeight] = useState(0); // 你还不知道真正的高度

  useLayoutEffect(() => {
    const { height } = ref.current.getBoundingClientRect();
    setTooltipHeight(height); // 现在重新渲染,你知道了真实的高度
  }, []);

  // ... 在下方的渲染逻辑中使用 tooltipHeight ...
}

如果你使用的是速度较慢的设备,你可能注意到有时 tooltip 会“闪烁”,并且会在更正位置之前短暂地看到初始位置。

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-12 03:40:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-12 03:40:04       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-12 03:40:04       82 阅读
  4. Python语言-面向对象

    2024-03-12 03:40:04       91 阅读

热门阅读

  1. 如何优雅的比较两个对象是否相等

    2024-03-12 03:40:04       43 阅读
  2. 在并发场景如何正确的使用锁机制呢?

    2024-03-12 03:40:04       44 阅读
  3. 7-Zip:一款免费开源但强大的压缩软件

    2024-03-12 03:40:04       47 阅读
  4. WPF实现一个表格数据从cs获取动态渲染

    2024-03-12 03:40:04       48 阅读
  5. 存储日期,该如何抉择呢

    2024-03-12 03:40:04       35 阅读
  6. SpringBoot集成Swagger3.0

    2024-03-12 03:40:04       37 阅读
  7. Linux——信号处理

    2024-03-12 03:40:04       42 阅读
  8. 整站下载保存为mhtml

    2024-03-12 03:40:04       42 阅读
  9. 376. 摆动序列(力扣LeetCode)

    2024-03-12 03:40:04       41 阅读
  10. Redis运行原理及基本数据类型

    2024-03-12 03:40:04       33 阅读
  11. Facebook和Instagram全球宕机,原因未披露

    2024-03-12 03:40:04       49 阅读