当前位置: 首页 > news >正文

【面试题】面试官:如果后端给你 1w 条数据,你如何做展示?

最近一位朋友参加阿b的面试,然后面试官问了她这个问题,我问她咋写的,她一脸淡定的说:“虚拟列表。”

大厂面试题分享 面试题库

前后端面试题库 (面试必备) 推荐:★★★★★

地址:前端面试题库

虚拟列表

What???

虚拟列表是个啥,我咋不知道😭

我就去查了一下,好家伙:

虚拟列表其实是按需显示的一种实现,即只对可见区域进行渲染,对非可见区域中的数据不渲染或部分渲染的技术,从而达到极高的渲染性能。

获取数据本身其实并没有那么消耗性能,渲染的过程才消耗时间,所以我们可以把渲染这一部分抽离出来,这样消耗的时间就减少了许多。

懒加载

我看着虚拟列表想了半天,这玩意和懒加载有啥区别吗?

我就默默去查了一下懒加载详细定义和实现:

懒加载也叫延迟加载,指的是在长网页中延迟加载图像,是一种很好优化网页性能的方式。用户滚动到它们之前,可视区域外的图像不会加载。这与图像预加载相反,在长网页上使用延迟加载将使网页加载更快。在某些情况下,它还可以帮助减少服务器负载。常适用图片很多,页面很长的电商网站场景中。

你仔细看看实现结构,懒加载的图片是已经存在的 div,已经放到 HTML 的结构里了。

我们再看看之前那个虚拟列表实现链接里的效果:

虚拟列表里面的渲染是动态的,当他不在视口可见,div 也不进行渲染了。

分页

我能想到的方式自然还有组件库自带的分页。

分片渲染

其实还有一个东西,叫分片渲染

分片渲染:简单的说就是一个执行完再执行下一个,其思想是建立一个队列,通过定时器来进行渲染,比如说一共有3次,先把这三个放入到数组中,当第一个执行完成后,并剔除执行完成的,在执行第二个,直到全部执行完毕,渲染队列清空。

如果我们一次性把所有的数据都进行渲染显然是会出现很大的问题,JS 的执行速度比 DOM 快得多,我们可以渲染一个 Item,让他一开始的展示与否为 false,然后我们一个一个的渲染或者100个100个的渲染,这样就解决了我们一次性渲染过多 的问题。

大厂面试题分享 面试题库

前后端面试题库 (面试必备) 推荐:★★★★★

地址:前端面试题库

相关文章:

  • 伯努利方程示例 Python 计算(汽水流体和喷泉工程)
  • 想要成为高级网络工程师,只需要具备这几点
  • 【Python练习】序列结构
  • 【微信小程序】-- 网络数据请求(十九)
  • 十大经典排序算法(上)
  • 【再谈动态规划】
  • 宇宙最强-GPT-4 横空出世:最先进、更安全、更有用
  • 刷题专练之链表(一)
  • Linux基础命令大全(上)
  • 总结:电容在电路35个基本常识
  • 2021电赛国一智能送药小车(F题)设计报告
  • 对于从事芯片行业的人来说,有哪些知识是需要储备的?
  • 【linux】Linux基本指令(上)
  • 拼多多24届暑期实习真题
  • 【JDK动态代理】及【CGLib动态代理】:Java的两种动态代理方式
  • JavaScript 如何正确处理 Unicode 编码问题!
  • (十五)java多线程之并发集合ArrayBlockingQueue
  • [rust! #004] [译] Rust 的内置 Traits, 使用场景, 方式, 和原因
  • angular组件开发
  • C语言笔记(第一章:C语言编程)
  • input实现文字超出省略号功能
  • Java超时控制的实现
  • Leetcode 27 Remove Element
  • Mithril.js 入门介绍
  • node和express搭建代理服务器(源码)
  • QQ浏览器x5内核的兼容性问题
  • React16时代,该用什么姿势写 React ?
  • 爱情 北京女病人
  • 大主子表关联的性能优化方法
  • 关于List、List?、ListObject的区别
  • 你真的知道 == 和 equals 的区别吗?
  • 前端面试题总结
  • 使用Envoy 作Sidecar Proxy的微服务模式-4.Prometheus的指标收集
  • 线性表及其算法(java实现)
  • 一天一个设计模式之JS实现——适配器模式
  • 鱼骨图 - 如何绘制?
  • UI设计初学者应该如何入门?
  • 阿里云移动端播放器高级功能介绍
  • # Swust 12th acm 邀请赛# [ A ] A+B problem [题解]
  • #免费 苹果M系芯片Macbook电脑MacOS使用Bash脚本写入(读写)NTFS硬盘教程
  • $L^p$ 调和函数恒为零
  • (C++20) consteval立即函数
  • (cos^2 X)的定积分,求积分 ∫sin^2(x) dx
  • (day 2)JavaScript学习笔记(基础之变量、常量和注释)
  • (八)Docker网络跨主机通讯vxlan和vlan
  • (附源码)ssm高校社团管理系统 毕业设计 234162
  • (介绍与使用)物联网NodeMCUESP8266(ESP-12F)连接新版onenet mqtt协议实现上传数据(温湿度)和下发指令(控制LED灯)
  • (免费领源码)Java#Springboot#mysql农产品销售管理系统47627-计算机毕业设计项目选题推荐
  • (原創) 是否该学PetShop将Model和BLL分开? (.NET) (N-Tier) (PetShop) (OO)
  • (转)Scala的“=”符号简介
  • ./include/caffe/util/cudnn.hpp: In function ‘const char* cudnnGetErrorString(cudnnStatus_t)’: ./incl
  • .babyk勒索病毒解析:恶意更新如何威胁您的数据安全
  • .htaccess配置常用技巧
  • .net core 调用c dll_用C++生成一个简单的DLL文件VS2008
  • .net 打包工具_pyinstaller打包的exe太大?你需要站在巨人的肩膀上-VC++才是王道