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()的资料请关注脚本之家其它相关文章!

相关文章

  • 微信小程序分包加载代码实现方法详解

    微信小程序分包加载代码实现方法详解

    这篇文章主要介绍了微信小程序分包加载代码实现方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • js的三种继承方式详解

    js的三种继承方式详解

    本文主要介绍了js的三种继承方式。具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • 前端流式接收数据示例讲解

    前端流式接收数据示例讲解

    在现代的前端应用中,处理大量数据和实时数据流变得越来越普遍,下面这篇文章主要介绍了前端流式接收数据的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-08-08
  • JavaScript实现刮刮乐效果

    JavaScript实现刮刮乐效果

    这篇文章主要为大家详细介绍了JavaScript实现刮刮乐效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • JS实现浏览器状态栏显示时间的方法

    JS实现浏览器状态栏显示时间的方法

    这篇文章主要介绍了JS实现浏览器状态栏显示时间的方法,涉及JavaScript针对时间及状态栏操作的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • JS实现根据详细地址获取经纬度功能示例

    JS实现根据详细地址获取经纬度功能示例

    这篇文章主要介绍了JS实现根据详细地址获取经纬度功能,涉及javascript与百度地图接口交互进行地址经纬度查询的相关操作技巧,需要的朋友可以参考下
    2019-04-04
  • 浅析showModalDialog数据缓存问题(用禁止浏览器缓存解决)

    浅析showModalDialog数据缓存问题(用禁止浏览器缓存解决)

    在使用showModalDialog弹出窗口时,显示的数据是上次修改前的数据,这是因为默认情况下页面保存了缓存,所以显示的数据并不是修改后的情况
    2013-07-07
  • 详解RequireJs官方使用教程

    详解RequireJs官方使用教程

    RequireJS以一个相对于baseUrl的地址来加载所有的代码。接下来通过本文给大家分享RequireJs官方使用教程,感兴趣的朋友一起看看吧
    2017-10-10
  • 基于d3.js/neovis.js/neod3.js实现链接neo4j图形数据库的图像化显示功能

    基于d3.js/neovis.js/neod3.js实现链接neo4j图形数据库的图像化显示功能

    neovis.js 由vis.js支持的图形可视化以及来自Neo4j的数据。这篇文章主要介绍了基于d3.js/neovis.js/neod3.js实现链接neo4j图形数据库的图像化显示功能,需要的朋友可以参考下
    2022-02-02
  • JavaScript中this指向机制与异步回调解决办法详解

    JavaScript中this指向机制与异步回调解决办法详解

    this的关键字是JavaScript中最复杂的机制之一,它是一个很特别的关键字,被自动定义在所有函数作用域中,这篇文章主要介绍了JavaScript中this指向机制与异步回调解决办法的相关资料,需要的朋友可以参考下
    2026-03-03

最新评论