news 2026/6/10 3:15:48

使用帧加载vue组件

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用帧加载vue组件

背景

首页渲染页面的时候,因为加载的元素特别多,页面会出现白屏

解决方案

使用浏览器的API requestAnimationFrame, 比如每一帧加载一个组件,依次加载所有的组件

举例说明

目录结构

components --HeavyComp.vue APP.vue useDefer.js

useDefer.js

import { ref } from 'vue'; export function useDefer(speed = 1) { const count = ref(0); let frame = 0; function update() { frame++; if (frame % Math.round(60 / speed) === 0) { count.value++; } requestAnimationFrame(update); } update(); return function (n) { return count.value >= n; }; }

APP.vue

<script setup> // import HelloWorld from './components/HelloWorld.vue' import HeavyComp from './components/HeavyComp.vue'; import { useDefer } from './useDefer.js'; const defer = useDefer(); </script> <template> <div> <a href="https://vite.dev" target="_blank"> <img src="/vite.svg" class="logo" alt="Vite logo" /> </a> <a href="https://vuejs.org/" target="_blank"> <img src="./assets/vue.svg" class="logo vue" alt="Vue logo" /> </a> </div> <!-- <div class="container"> <div v-for="n in 100" :key="n"> <heavy-comp></heavy-comp> </div> </div> --> <div class="container"> <div v-for="n in 100" :key="n"> <heavy-comp v-if="defer(n)"></heavy-comp> </div> </div> </template> <style scoped> .logo { height: 6em; padding: 1.5em; will-change: filter; transition: filter 300ms; } .logo:hover { filter: drop-shadow(0 0 2em #646cffaa); } .logo.vue:hover { filter: drop-shadow(0 0 2em #42b883aa); } .container { display: grid; grid-template-columns: repeat(3, 1fr); grid-gap: 1em; } </style>

HeavyComp.vue

<script setup> import { ref } from 'vue' defineProps({ msg: String, }) const count = ref(50) </script> <template> <div v-for="i in count" :key="i"> <p> Check out <a href="https://vuejs.org/guide/quick-start.html#local" target="_blank" >create-vue</a >, the official Vue + Vite starter </p> <p> Learn more about IDE Support for Vue in the <a href="https://vuejs.org/guide/scaling-up/tooling.html#ide-support" target="_blank" >Vue Docs Scaling up Guide</a >. </p> <a href="https://vite.dev" target="_blank"> <img src="/vite.svg" class="logo" alt="Vite logo" /> </a> <a href="https://vuejs.org/" target="_blank"> <img src="../assets/vue.svg" class="logo vue" alt="Vue logo" /> </a> </div> </template> <style scoped> .read-the-docs { color: #888; } </style>

效果展示

组件会一步步加载,公司禁止图片,老弟这里没法贴图。自己运行代码查看吧。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 11:37:15

1小时搭建OCR原型:快马平台实战演示

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 在快马平台上快速构建一个OCR原型应用。前端提供图片上传界面和结果显示区域&#xff0c;后端集成OCR API服务。实现基本功能&#xff1a;接收用户上传的图片&#xff0c;调用OCR服…

作者头像 李华
网站建设 2026/6/10 11:37:19

Redux在大型SaaS应用中的架构实践

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 请设计一个适合大型SaaS应用的Redux架构方案。要求&#xff1a;1.使用Redux Toolkit 2.支持动态加载reducer 3.实现状态持久化 4.包含错误处理中间件 5.支持撤销/重做功能 6.提供性…

作者头像 李华
网站建设 2026/6/10 11:42:44

33、Linux线程同步与互斥

Linux线程同步与互斥 一、核心理论基础&#xff1a;互斥与同步 1. 互斥&#xff08;Mutex&#xff09;&#xff1a;临界资源的排他性访问 核心概念 临界资源&#xff1a;多线程中需共同读写的资源&#xff08;如全局变量、文件、硬件设备&#xff09;&#xff0c;同一时刻只…

作者头像 李华
网站建设 2026/6/10 13:19:26

2024-2025阶段感悟

一、核心理念体系&#xff1a;心想事成 心学 基因 易经 你提出了一套以“心”为本、贯通中西、融合科学与灵性的成功/疗愈/创造模型&#xff0c;其底层逻辑可概括为&#xff1a;心之所向 → 潜意识重塑 → 能量聚焦 → 现实显化 这一过程&#xff0c;既是吸引力法则的实践&a…

作者头像 李华
网站建设 2026/6/9 19:47:03

GEO优化实战指南:如何让品牌在AI搜索中被优先引用

在GEO优化时代&#xff0c;搜索引擎不再只是提供一串蓝色链接等待用户点击&#xff0c;而是直接在搜索结果页面展示完整答案。这种行为被称为“零点击搜索”&#xff0c;意味着用户无需进入网站即可获取信息&#xff0c;这对内容曝光与商业转化提出了新挑战。传统SEO以关键词排…

作者头像 李华
网站建设 2026/6/10 10:55:27

FPGA在AI时代的角色重塑:硬件可重构性与异构计算的完美结合

引言&#xff1a;当摩尔定律放缓&#xff0c;架构创新登场截至2025年&#xff0c;半导体行业已普遍接受一个不可逆的事实&#xff1a;晶体管微缩带来的性能红利正在枯竭。台积电3nm工艺的每晶体管成本不降反升&#xff0c;而2nm以下制程面临量子隧穿、原子级制造等物理极限。国…

作者头像 李华