• 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 ...
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

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

  • 相关阅读:
    Vue---反向传值
    自己动手从零写桌面操作系统GrapeOS系列教程——1.1 GrapeOS介绍
    PLC电力载波通讯,一种新的IoT通讯技术
    五分钟搞懂python生成器迭代器
    go mod tidy 报错:x509: certificate signed by unknown authority 最佳实践
    【iOS开发】—— weak底层原理
    九、【React基础】组件的生命周期
    Java实现图片和Base64之间的相互转化
    6-羧基四甲基罗丹明,CAS号: 91809-67-5
    RabbitMQ基础
  • 原文地址:https://blog.csdn.net/qq_36413371/article/details/136535331