news 2026/5/26 2:53:46

使用帧加载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/5/25 10:17:37

企业级Oracle RAC集群实战安装指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个Oracle RAC集群部署模拟器&#xff0c;模拟2节点RAC环境的安装过程。要求&#xff1a;1) 可视化展示共享存储配置(ASM) 2) 网络拓扑图展示(public/private网络) 3) 分步演示…

作者头像 李华
网站建设 2026/5/25 13:44:01

三分钟构建智能AI集群:Exo资源配额自动分配全解析

三分钟构建智能AI集群&#xff1a;Exo资源配额自动分配全解析 【免费下载链接】exo Run your own AI cluster at home with everyday devices &#x1f4f1;&#x1f4bb; &#x1f5a5;️⌚ 项目地址: https://gitcode.com/GitHub_Trending/exo8/exo 还在为家中闲置设备…

作者头像 李华
网站建设 2026/5/25 16:13:54

国产出图神器!行政边界一键填充配色、秒出专业图,附完整教程

告别繁琐&#xff0c;三步出图&#xff01;从加载数据、自定义配色到添加指北针、比例尺等专业元素&#xff0c;Bigemap Pro助你轻松完成一张规范、美观的行政边界图。支持直接打印&#xff0c;或导出高清PDF无缝嵌入汇报PPT。一、行政边界图制作全流程详解 1. 数据加载与边界提…

作者头像 李华
网站建设 2026/5/26 8:25:12

测试精粹:资深专家的十项实战心法

测试专家的价值与时代意义 在数字化浪潮席卷全球的今天&#xff0c;软件质量已成为企业竞争力的核心要素。作为软件测试从业者&#xff0c;我们不仅是缺陷的发现者&#xff0c;更是质量文化的推动者。测试专家通过多年的项目历练&#xff0c;总结出宝贵的经验教训&#xff0c;…

作者头像 李华
网站建设 2026/5/25 14:17:28

完整指南:用Figma-Context-MCP实现AI助手与设计稿的智能对话

完整指南&#xff1a;用Figma-Context-MCP实现AI助手与设计稿的智能对话 【免费下载链接】Figma-Context-MCP MCP server to provide Figma layout information to AI coding agents like Cursor 项目地址: https://gitcode.com/gh_mirrors/fi/Figma-Context-MCP 想要让…

作者头像 李华
网站建设 2026/5/25 14:29:45

AI 正在“吃光内存”,NVIDIA与SK海力士把目光投向了 NAND

继大规模蚕食DRAM市场后&#xff0c;英伟达与SK海力士计划推出性能提升近10倍的"AI SSD"&#xff0c;引发NAND供应警报。随着AI产业重心从训练转向推理&#xff0c;技术栈需全面升级以构建低延迟、高吞吐环境&#xff0c;行业正聚焦通过NAND芯片打造推理优化的AI存储…

作者头像 李华