前端开发攻略---在页面上渲染大量元素,使用defer减少白屏等待时间,优化页面响应速度

本文主要是介绍前端开发攻略---在页面上渲染大量元素,使用defer减少白屏等待时间,优化页面响应速度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、优化前

2、优化后

 3、优化思路

1、在元素数量不变的情况下,进行一步一步的渲染,先渲染一些重要的元素或者需要用户第一时间看到的元素。

2、使用Hooks封装优化函数

4、优化代码

拥有大量元素的组件(Item):文件位置:components > Item > index.vue

<template><div class="content"><span v-for="item in 5000">{{ item }},</span></div>
</template><script setup>
import { ref, reactive } from 'vue'
</script><style scoped lang="scss">
.content {padding: 10px;border: 1px solid red;display: flex;flex-wrap: wrap;
}
</style>

这里在App.vue组件中使用这个 Item 组件

<template><div class="container"><div v-for="n in 100"><Item v-if="defer(n)"></Item></div></div>
</template><script setup>
import { ref } from 'vue'
import Item from '@/components/Item/index.vue'
import { useDefer } from '@/hooks/useDefer'const defer = useDefer()
</script><style scoped lang="scss">
.container {display: grid;grid-template-columns: repeat(3, 1fr);grid-gap: 1em;
}
</style>

hooks文件:文件位置:hooks > useDefer.js

import { ref, onUnmounted } from 'vue'
export function useDefer(maxCount = 100) {const frameCount = ref(1)let rafId = nullfunction updateFrameCount() {rafId = requestAnimationFrame(() => {frameCount.value++if (frameCount.value >= maxCount) {return}updateFrameCount()})}updateFrameCount()onUnmounted(() => {cancelAnimationFrame(rafId)})return function (n) {return frameCount.value >= n}
}

useDefer函数代码解释:

  1. import { ref, onUnmounted } from 'vue': 这里导入了 Vue 的 ref 和 onUnmounted 方法,用于创建响应式数据和在组件销毁时执行清理操作。

  2. export function useDefer(maxCount = 100) { ... }: 这是一个导出的函数,接受一个参数 maxCount,默认值为 100。这个参数用于设置最大的帧数,也就是最大的渲染延迟量。

  3. const frameCount = ref(1): 创建一个名为 frameCount 的响应式引用,用于追踪当前帧数。

  4. let rafId = null: 创建一个变量 rafId,用于存储 requestAnimationFrame 的返回值,以便后续取消渲染帧的请求。

  5. function updateFrameCount() { ... }: 这是一个内部函数,用于更新帧数。它使用 requestAnimationFrame 来递增 frameCount 的值,直到达到 maxCount

  6. updateFrameCount(): 调用 updateFrameCount 函数,开始更新帧数。

  7. onUnmounted(() => { ... }): 使用 onUnmounted 钩子,当组件被销毁时,取消 requestAnimationFrame

  8. return function (n) { ... }: 返回一个函数,这个函数接受一个参数 n,表示需要渲染的项目索引。在这个返回的函数中,它会检查当前帧数是否大于等于 n,如果是,则表示可以渲染该项目,否则需要延迟渲染。

总体来说,这段代码的作用是创建一个可以控制渲染延迟的函数,并在组件销毁时清理相关资源,这样可以有效地优化页面加载性能。

这篇关于前端开发攻略---在页面上渲染大量元素,使用defer减少白屏等待时间,优化页面响应速度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/912070

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

Vim使用基础篇

本文内容大部分来自 vimtutor,自带的教程的总结。在终端输入vimtutor 即可进入教程。 先总结一下,然后再分别介绍正常模式,插入模式,和可视模式三种模式下的命令。 目录 看完以后的汇总 1.正常模式(Normal模式) 1.移动光标 2.删除 3.【:】输入符 4.撤销 5.替换 6.重复命令【. ; ,】 7.复制粘贴 8.缩进 2.插入模式 INSERT

JAVA读取MongoDB中的二进制图片并显示在页面上

1:Jsp页面: <td><img src="${ctx}/mongoImg/show"></td> 2:xml配置: <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001

vue, 左右布局宽,可拖动改变

1:建立一个draggableMixin.js  混入的方式使用 2:代码如下draggableMixin.js  export default {data() {return {leftWidth: 330,isDragging: false,startX: 0,startWidth: 0,};},methods: {startDragging(e) {this.isDragging = tr

Lipowerline5.0 雷达电力应用软件下载使用

1.配网数据处理分析 针对配网线路点云数据,优化了分类算法,支持杆塔、导线、交跨线、建筑物、地面点和其他线路的自动分类;一键生成危险点报告和交跨报告;还能生成点云数据采集航线和自主巡检航线。 获取软件安装包联系邮箱:2895356150@qq.com,资源源于网络,本介绍用于学习使用,如有侵权请您联系删除! 2.新增快速版,简洁易上手 支持快速版和专业版切换使用,快速版界面简洁,保留主

如何免费的去使用connectedpapers?

免费使用connectedpapers 1. 打开谷歌浏览器2. 按住ctrl+shift+N,进入无痕模式3. 不需要登录(也就是访客模式)4. 两次用完,关闭无痕模式(继续重复步骤 2 - 4) 1. 打开谷歌浏览器 2. 按住ctrl+shift+N,进入无痕模式 输入网址:https://www.connectedpapers.com/ 3. 不需要登录(也就是

JavaScript全屏,监听页面是否全屏

在JavaScript中,直接监听浏览器是否进入全屏模式并不直接支持,因为全屏API主要是关于请求和退出全屏模式的,而没有直接的监听器可以告知页面何时进入或退出全屏模式。但是,你可以通过在你的代码中跟踪全屏状态的改变来模拟这个功能。 以下是一个基本的示例,展示了如何使用全屏API来请求全屏模式,并在请求成功或失败时更新一个状态变量: javascriptlet isInFullscreen =

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主