zarte
V2EX  ›  问与答

vue 页面卡顿如何优化?

  •  
  •   zarte · Aug 31, 2020 · 3843 views
    This topic created in 2107 days ago, the information mentioned may be changed or developed.

    v-for 方式生成 5 百多个 table (非组件),每个一百条数据以内字段不固定。之前发帖问了已正确设置唯一 key 。数据为动态 push 到数组渲染的。 页面任何操作输入文字,点击按钮啥的都卡。。。

    8 replies    2020-09-01 10:34:30 +08:00
    seki
        1
    seki  
       Aug 31, 2020   ❤️ 1
    1.分页
    1.滚动加载
    1.虚拟渲染,例如 https://github.com/Akryum/vue-virtual-scroller
    seki
        2
    seki  
       Aug 31, 2020
    也可以检查一下你的代码,是不是你输入一下文字和点击一下按钮就会弄得整个页面都重新渲染了,适当地抽象化组件实现部分重渲染说不定也能解决问题
    meathill
        3
    meathill  
       Aug 31, 2020
    500 多个 table,每个 100 条数据,怎么都会卡……

    方案:

    1. 不要用 table,用 grid + 限制列宽
    2. 动态加载,保证同时只有少数几个表格在渲染
    sixway
        4
    sixway  
       Aug 31, 2020
    可以打开调试工具那里渲染花费了。
    chrome 的 Performance
    murmur
        5
    murmur  
       Aug 31, 2020
    页面发出来看看,这东西不给代码怎么回答你?
    jydeng
        6
    jydeng  
       Aug 31, 2020
    虚拟滚动
    zarte
        7
    zarte  
    OP
       Sep 1, 2020
    @meathill 嗯,我试下
    redbuck
        8
    redbuck  
       Sep 1, 2020
    $('*').length 看下有多少 dom
    dom 多可以懒加载.

    table 加个 v-if,容器加个最小高度,再监听滚动事件(节流),进入视口的解除 v-if,离开的恢复 v-if.最好封装成指令.
    数据量太大,又不用变化的,Object.freeze.
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   966 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 39ms · UTC 21:43 · PVG 05:43 · LAX 14:43 · JFK 17:43
    ♥ Do have faith in what you're doing.