V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
thinkershare
V2EX  ›  问与答

浏览器页面渲染性能问题优化

  •  
  •   thinkershare · 2021-11-26 11:42:18 +08:00 · 924 次点击
    这是一个创建于 1120 天前的主题,其中的信息可能已经有所发展或是发生改变。

    代码

    <div id="box">
    	<div class="device" />
        <div class="device" />
        <div class="device" />
        <div class="device" />
        .....
    </div>
    

    问题

    1. #box 使用了相对定位, 需要鼠标拖动, 通过修改 left/top 实现,
    2. .device 数量很多, 50+到 500 个不等, 隐藏所有.device 时候, 拖动很流畅, 如果显示则拖动有明显的卡顿(.device 使用绝对定位)

    有啥性能优化建议吗?

    makelove
        1
    makelove  
       2021-11-26 11:58:58 +08:00   ❤️ 1
    transform 配 translateX/Y 也能定位,性能要更好。其中 3d 版会用硬件加速,可以先试非 3d 版不行再换 3d 版
    renmu123
        2
    renmu123  
       2021-11-26 12:09:23 +08:00 via Android   ❤️ 2
    box 改绝对定位,修改 left 变成修改 transform ,性能应该高上一点,再加个 will-change 试试看
    des
        3
    des  
       2021-11-26 12:20:13 +08:00 via iPhone   ❤️ 1
    试试经典的 transformZ(0) ?
    thinkershare
        4
    thinkershare  
    OP
       2021-11-26 12:27:53 +08:00
    OK, 我先试一试, 感谢给位大大
    thinkershare
        5
    thinkershare  
    OP
       2021-11-26 13:40:37 +08:00   ❤️ 1
    问题已经解决: 使用 transformZ(0)联合 will-change:transform, CPU 占用就下降了, 一切工作正常
    thinkershare
        6
    thinkershare  
    OP
       2022-01-07 13:39:44 +08:00
    发现数据多了还是不行, 看来只能换成 canvas
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2693 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 02:09 · PVG 10:09 · LAX 18:09 · JFK 21:09
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.