JS使用window.requestAnimationFrame()对列表切片进行渲染

 更新时间:2023年05月29日 09:31:12   作者:fuGUI  
这篇文章主要为大家介绍了JS使用requestAnimationFrame对列表切片进行渲染,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

背景

正常的后端返回几十条数据数据直接渲染还好,但是现在需求是表格上面的每一行数据都要编辑的操作(各种下拉和输入),最后整体保存,保存完成后再次进来回显之前的已经填的数据,现在的问题是每次回显比较慢(接口数据很快就返回了),在页面很卡顿,体验很不好。

问题排查

通过审查代码也没发现什么问题,找不出原因,代码逻辑是很简单的,就是等接口数据返回然后赋值给表格展示,到页面就loading了。。

问题解决

之前看到了列表可以切片渲染,就是前端对数据做一个分页然后按照顺序加载,假设每个页面都有 limit 记录,那么数据可以分为 Math.ceil(total/limit) 个页面。然后可以使用setTimeout顺序渲染页面,一次只渲染一个页面。

  • 使用setTimeout
const renderList(list = []){
  const total = list.length
  const page = 0
  const limit = 200
  const totalPage = Math.ceil(total / limit)
  const render = (page) => {
    if (page >= totalPage) return
    setTimeout(() => {
      for (let i = page * limit; i < page * limit + limit; i++) {
        const item = list[i]
        if(item) {
          // ...这里写当前表格赋值逻辑
          // this.tableData.push(item)
        }
      }
      render(page + 1)
    },0)
  }
  render(page)
}
  • 使用requestAnimationFrame来代替 setTimeout
readerList(list = []) {
      const total = list.length
      const page = 0
      const limit = 10
      const totalPage = Math.ceil(total / limit)
      const render = (page) => {
        if (page >= totalPage) return
          for (let i = page * limit; i < page * limit + limit; i++) {
            const item = list[i]
            if(item) {
               // ...这里写当前表格赋值逻辑
               // this.tableData.push(item)
            }
          }
          requestAnimationFrame(() => { render(page + 1) })
      }
      requestAnimationFrame(() => { render(page) })
    }

关于requestAnimationFrame

requestAnimationFrame

window.requestAnimationFrame() 告诉浏览器——你希望执行一个动画,并且要求浏览器在下次重绘之前调用指定的回调函数更新动画。该方法需要传入一个回调函数作为参数,该回调函数会在浏览器下一次重绘之前执行。
备注: 若你想在浏览器下次重绘之前继续更新下一帧动画,那么回调函数自身必须再次调用 requestAnimationFrame()。requestAnimationFrame() 是一次性的。

requestAnimationFrame 比起 setTimeout、setInterval的优势主要有两点:

  • requestAnimationFrame 会把每一帧中的所有DOM操作集中起来,在一次重绘或回流中就完成,并且重绘或回流的时间间隔紧紧跟随浏览器的刷新频率,一般来说,这个频率为每秒60帧。
  • 在隐藏或不可见的元素中,requestAnimationFrame 将不会进行重绘或回流,这当然就意味着更少的cpu,gpu和内存使用量。

以上就是JS使用window.requestAnimationFrame()对列表切片进行渲染的详细内容,更多关于JS window.requestAnimationFrame()的资料请关注脚本之家其它相关文章!

相关文章

  • 详解GoJs节点的选中高亮实现示例

    详解GoJs节点的选中高亮实现示例

    这篇文章主要为大家介绍了GoJs节点的选中高亮实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • js改变embed标签src值的方法

    js改变embed标签src值的方法

    这篇文章主要介绍了js改变embed标签src值的方法,涉及javascript操作元素属性的技巧,非常具有实用价值,需要的朋友可以参考下
    2015-04-04
  • 容易造成JavaScript内存泄露几个方面

    容易造成JavaScript内存泄露几个方面

    这篇文章主要介绍了容易造成JavaScript内存泄露几个方面,本文讲解了多个会在Chrome V8中产生内存泄漏的示例,需要的朋友可以参考下
    2014-09-09
  • JS清除选择内容的方法

    JS清除选择内容的方法

    这篇文章主要介绍了JS清除选择内容的方法,较为详细的分析了js操作文本的技巧,需要的朋友可以参考下
    2015-01-01
  • uniapp中安装axios并解决跨域问题小结

    uniapp中安装axios并解决跨域问题小结

    跨域(Cross-Origin)是指在浏览器中,当前网页的协议、域名或端口与请求目标的协议、域名或端口不相同,即存在跨域请求的情况,这篇文章主要介绍了uniapp中安装axios并解决跨域问题小结,需要的朋友可以参考下
    2024-05-05
  • 关于layui toolbar和template的结合使用方法

    关于layui toolbar和template的结合使用方法

    今天小编就为大家分享一篇关于layui toolbar和template的结合使用方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09
  • Three.js实现3D乒乓球小游戏(物理效果)

    Three.js实现3D乒乓球小游戏(物理效果)

    本文将使用React Three Fiber 和 Cannon.js 来实现一个具有物理特性的乒乓球小游戏,使用 React Three Fiber 搭建基础三维场景、如何使用新技术栈给场景中对象的添加物理特性等,最后利用上述知识点,将开发一个简单的乒乓球小游戏,需要的朋友可以参考下
    2023-03-03
  • 判断是否存在子节点的实现代码

    判断是否存在子节点的实现代码

    下面小编就为大家带来一篇判断是否存在子节点的实现代码。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-05-05
  • JavaScript实现楼梯滚动特效(jQuery实现)

    JavaScript实现楼梯滚动特效(jQuery实现)

    这篇文章主要为大家详细介绍了JavaScript实现楼梯滚动特效,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • 图片连续滚动代码[兼容IE/firefox]

    图片连续滚动代码[兼容IE/firefox]

    网上有不少的连续滚动实现代码,下面的这个是兼容性不错的代码。大家可以测试下。
    2009-06-06

最新评论