百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

前端面试题-给你十万条数据,如何顺滑的渲染出来?

zhezhongyun 2025-01-29 19:07 33 浏览

首先声明这是一道面试题,可能很多人第一眼看到这个面试题的时候,脑海中的第一映像就是通过for循环来进行渲染吧,但是这个方案确实是不敢恭维呢!那还有其他的解决方案么?

基本实现方案

虽然说for循环的方式确实有点low,但是既然是面试题,面试官也不傻,如果你这样说了,面试官会继续问,为什么会让浏览器崩溃的时候,你就不知道咋回答了。

首先简单的例举个场景,如果我们在一个容器ul中去循环十万的li标签。

我们的思路是打印js运行时间和页面渲染时间,第一个console.log的触发时间是在页面进行渲染之前,此时得到的间隔时间为JS运行所需要的时间;第二个console.log是在 setTimeout 中的,它的触发时间是在渲染完成,在下一次Event Loop中执行的。





  
  
  Document



  

    上面这段代码的执行效果,开销真的太大了,而且需要加载十万条数据,在数据没有完成之前,页面一直是白屏,并且在向下滑动的过程中,也会出现卡顿的现象。基于这种实现方式,显然不是我们想要的结果,这就需要我们提出新的方案来解决。

    定时器渲染

    我们可以使用定时器加分页操作来实现渲染。代码如下

    
    
    
    
      
      
      Document
    
    
    
      

      这样我们会看到十万条的数据并不是一次性的进行了加载,而是随着定时器的执行逐步进行加载,并且会在浏览器右侧有滑动的效果,但是如果我们滑动屏幕的速度太快的话还没有等到数据加载完成的时候还是会出现白屏的情况。这就需要我们继续对操作方式进行优化了。

      requestAnimationFrame

      requestAnimationFrame方法,用于在下一次浏览器重绘之前调用一个指定的函数方法,是由HTML5提供的API方案。

      requestAnimationFrame 和 setTimeout 的区别:

      • requestAnimationFrame的调用频率通常为每秒60次。这意味着我们可以在每次重绘之前更新动画的状态,并确保动画流畅运行,而不会对浏览器的性能造成影响。
      • setInterval与setTimeout它可以让我们在指定的时间间隔内重复执行一个操作,不考虑浏览器的重绘,而是按照指定的时间间隔执行回调函数,可能会被延迟执行,从而影响动画的流畅度

      还有一个问题就是,在操作过程中多次创建了il挂载到了ul上,这样会导致回流,所以可以使用虚拟文档片段的方式对其进行优化,这是因为这种操作并不会触发到DOM树的重新渲染。

      
      
      
      ![rf.gif](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/3eab42b37f53408b981411ee54088d5a~tplv-k3u1fbpfcp-watermark.image?)
      
        
        
        Document
      
      
      ![st.gif](https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/3e922cc57a044f5e9e48e58bda5f6756~tplv-k3u1fbpfcp-watermark.image?)
      
        

        上面这种方式,要比之前的方式好,但是在操作的过程中还是有一些不友好的地方。那还有更好的方式来解决这种问题么?

        虚拟列表

        接触过Android开发的时候,我们有过这样的操作,就是渲染一个列表的时候需要一个适配器,并且在创建Item的时候,只需要替换其中的数据,而不需要每次都重新加Item,这种方式的实现前提就是我们需要知道手机屏幕可以放下多少条数据,并且为了避免滑动的太快导致白屏现象,我们还引入了预加载的操作。可以提前加载一些数据等待用户使用。

        实现方案如下。

        
        
        
        
          
          
          
          虚拟列表
          
        
        
        
          
        {{ item.msg }}

        会看到这种方式的实现基本上不会再出现上面的各种问题。可以更加高效的执行数据渲染的操作。

        总结

        一般在处理大量数据的时候所采取的方式都是分而治之的方式,通过将数据拆分成不同的小段来提升加载的效率。也希望这种思路能被更多的开发者所接收。

        相关推荐

        写作排版简单三步就行-工具篇(作文排版编辑软件)

        和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...

        CSS继承的元素属性小总结(css 继承性)

        所有元素可继承:visibility和cursor内联元素和块级元素可继承:letter-spacingword-spacingwhite-spaceline-heightcolorfontfont-...

        Cube 技术解读 | Cube 小程序技术详解

        作者:曾维宏(恒实)“本文为《Cube技术解读》系列第三篇文章,之前上线的《支付宝新一代动态化技术架构与选型综述》《Cube卡片技术栈解读》欢迎大家回顾。”小程序作为动态化或者跨端开发的一种技术栈...

        “战斗民族”这样为新生儿检查?(战斗民族)

        <fontface="近日,一条被称为“俄罗斯新生儿检查”的视频在微博疯传,视频中检查者粗鲁的动作让网友们纷纷感染“怪不得是战斗民族”。视频真实性有待考证,但宝宝出生后确实需要马不停蹄地做一系...

        实测,大模型谁更懂数据可视化?(实测,大模型谁更懂数据可视化技术)

        大家好,我是Ai学习的老章看论文时,经常看到漂亮的图表,很多不知道是用什么工具绘制的,或者很想复刻类似图表。实测,大模型LaTeX公式识别,出乎预料前文,我用Kimi、Qwen-3-235B...

        「Python爬虫」:破解网站字体加密和反反爬虫

        前言:字体反爬,也是一种常见的反爬技术,例如58同城,猫眼电影票房,汽车之家,天眼查,实习僧等网站。这些网站采用了自定义的字体文件,在浏览器上正常显示,但是爬虫抓取下来的数据要么就是乱码,要么就是变成...

        转录组及可视化分析——样本间相关性绘图

        背景介绍在进行正式的转录组分析之前,一般可以先对样本的相关性进行绘图,用于观察各个组之间或组内样本的相关性。数据介绍数据的话我们采用的是送样测序公司反馈给我们的gene_count文件,格式如下:...

        阿里巴巴矢量图标库 iconfont 的使用方法

        xx-blog主题使用的图标库是阿里巴巴的iconfont,因此这里介绍一下此主题库的用法。首先去iconfont主题库,注册一个账号,然后就可以找自己喜欢的图标了,找到后点击添加购物车,就回到了右侧...

        五行取名(五行取名的正确方法)

        1、五行的分类原则以方位来论:东方属木;南方属火;西方属金;北方属水;中央属土。以季节来论:春季属木;夏季属火;秋季属金;冬季属水;季末属土。以气候来论:风属木;暑属火;燥属金;寒属水;湿属土。以颜色...

        4K显示器软件界面字体过小解决方法

        用4K显示器(win10或者win11下)的朋友会发现一些软件并不能随着系统的字体放大而放大字体,用起来很不方便。譬如常用的ps或者行业专用软件。笔者经过摸索,发现这样设置一下可以解决。下面以Psc...

        VBA之Word应用:利用Range方法进行字体及对齐方式设置

        《VBA之Word应用》(版权10178982),是我推出第八套教程,教程是专门讲解VBA在Word中的应用,围绕“面向对象编程”讲解,首先让大家认识Word中VBA的对象,以及对象的属性、方法,然后...

        办公小技巧:告别侵权 PPT字体自己造

        很多朋友还不知道,我们每天面对的字体都是有版权保护的,如果对这方面的内容不了解,一不小心就可能造成侵权。那么我们在日常设计PPT文稿的时候,如何避免字体侵权呢?首先我们得懂得如何查看版权信息,另外还需...

        显示器颜色显示有偏差?你校准过吗?

        编辑:晴晨购物、拍照、做视频、玩游戏……看似不一样的操作都怕一件事:颜色有偏差。购物时商品颜色有出入,毫不知情的情况下把责任推给了商家,那么拍照、做视频、玩游戏呢?我们先来看看某网友的诉苦:“我的是台...

        设计字体那些事(设计字体种类大全图)

        做设计几年,平均每年都能遇见好多因为字体侵权的事情,今天就结合我自己的经验和了解简单介绍下字体那些事#毒角SHOW角角用了这款字体,竟被送律师函赔偿10万https://www.douyin.com...

        LCD智能显示模块-绘图板(lcd显示模块流程图)

        TOPWAY智能模块(SmartLCD)是专门为工业显示应用而设计的TFT液晶显示模块。我司自主研发的界面编辑软件RGTools/SGTools提供了18个控件,通过些控件能实现丰富的显...