还用 v-for 渲染大列表?Vue-Infinity 让内存直降 90%!
haoteby 2025-09-08 20:51 24 浏览
大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。
什么是 Vue-Infinity
Vue-Infinity 是一个模块化工具包,旨在帮助开发者使用 Vue 构建高性能、内存高效且富媒体的应用程序。通过利用智能数据获取和虚拟化渲染,即使在处理大型数据集时也能确保流畅的用户体验。
Vue-Infinity 运用与 3D 引擎相同的原理,大幅提升 UI 的效率,即不可见的内容不会被渲染。这使得应用能够处理数百或数千个元素,而不会造成内存膨胀、卡顿或电池耗尽。无论是构建无限的动态、轮播、媒体库还是仪表盘,Vue-Infinity 都能让应用保持快速、流畅和高效。
Vue-Infinity 的主要功能包括:
- 通过 Ghost 组件有条件地渲染其插槽内容来优化性能。当内容离开屏幕时,其会被尺寸相同的占位符替换,从而 “卸载” 较重的元素(例如:视频),同时保留布局。
- 高性能:卸载屏幕外的内容以释放资源
- 布局稳定性:用大小合适的占位符替换隐藏的内容
- 事件驱动:当组件内容变为可见或隐藏时触发事件:on-load:当组件内容变为可见并渲染时触发before-unload:在组件内容开始隐藏的同一 tick 内触发on-unload:在组件内容隐藏并被占位符替换后的下一个 tick 内触发
目前 Vue-Infinity 在 Github 通过 MIT 协议开源,是一个值得关注的前端开源项目。
如何使用 Vue-Infinity
使用 InfiniteCarousel
一款通用虚拟滚动组件,针对网格或轮播布局进行了优化,可直接与 InfiniteList 集成,用于管理数据访问,并支持以下特性:
- 可自定义行数和列数
- 可配置为水平或垂直滚动条
- 支持每个项目自定义模板
- 支持自定义加载模板
- 允许使用基于 CSS 的滚动捕捉功能滚动到任何项目
- 通过提供 onGetItemAspectRatio 回调函数来支持动态调整项目大小。
<template>
<InfiniteCarousel
:infinite-list="infiniteList"
:height="'50vh'"
:width="'100%'"
:numColsToShow="3"
:numRowsToShow="2"
>
<template #item="{ item, index}">
<img :src="item.url" :alt="item.title" class="carousel-img"/>
</template>
</InfiniteCarousel>
</template>
<script setup>
import {useInfiniteList} from 'vue-infinity';
const infiniteList = useInfiniteList({
fetchItems: (page) => fetchPage(page),
itemsPerPage: 20,
maxPagesToCache: 5
});
</script>
使用 v-ghost 指令
v-ghost 指令提供了一种轻量、灵活的 Ghost 组件替代方案,用于优化性能。通过将 v-ghost 应用于任何元素,开发者可以确保其内容仅在进入视口时渲染。当元素离开屏幕时,其内容将被占位符替换,从而保持布局完整性并释放系统资源。
<template>
<video controls muted playsinline v-ghost>
<source src="your-video.mp4" type="video/mp4" />
</video>
</template>
AutoObserver
增强了原生 IntersectionObserver 的功能,自动处理新增元素并清理已移除元素,核心特征包括:
- 观察新增元素
- 停止观察已移除元素
- 允许使用自定义逻辑过滤要观察的元素
- 组件卸载时自动清理
const containerRef = ref<HTMLElement>();
const {disconnect} = useAutoObserver(
containerRef,
(entries) => {
entries.forEach(entry => {
console.log('Element visibility changed:', entry.isIntersecting);
});
},
{
rootMargin: '200px',
threshold: 0.1,
filter: el => el.classList.contains('observe-me')
}
);
参考资料
https://github.com/isaact/vue-infinity?tab=readme-ov-file#vue-infinity
https://tewolde.co/vueInfinity/
相关推荐
- 如何随时清理浏览器缓存_清理浏览器缓存怎么弄
-
想随时清理浏览器缓存吗?Cookieformac版是Macos上一款浏览器缓存清理工具,所有的浏览器Cookie,本地存储数据,HTML5数据库,FlashCookie,Silverlight,...
- Luminati代理动态IP教程指南配置代理VMLogin中文版反指纹浏览器
-
介绍如何使用在VMLogin中文版设置Luminati代理。首先下载VMLogin中文版反指纹浏览器(https://cn.vmlogin.com)对于刚接触Luminati动态ip的朋友,是不是不懂...
- mac清除工具分享,解除您在安全方面的后顾之忧
-
想要永久的安全的处理掉重要数据,删除是之一,使用今天小编分享的mac清除工具,为您的操作再增一层“保护”,小伙伴慎用哟,一旦使用就不可以恢复咯,来吧一起看看吧~mac清除工具分享,解除您在安全方面的后...
- 取代cookie的网站追踪技术:”帆布指纹识别”
-
【前言】一般情况下,网站或者广告联盟都会非常想要一种技术方式可以在网络上精确定位到每一个个体,这样可以通过收集这些个体的数据,通过分析后更加精准的去推送广告(精准化营销)或其他有针对性的一些活动。Co...
- 辅助上网为啥会被抛弃 曲奇(Cookie)虽甜但有毒
-
近期有个小新闻,大概很多小伙伴都没有注意到,那就是谷歌Chrome浏览器要弃用Cookie了!说到Cookie功能,很多小伙伴大概觉得不怎么熟悉,有可能还不如前一段时间被弃用的Flash“出名”,但它...
- 浏览器指纹是什么?浏览器指纹包括哪些信息
-
本文关键词:浏览器指纹、指纹浏览器、浏览器指纹信息、指纹浏览器原理什么是浏览器指纹?浏览器指纹是指浏览器的各种信息,当我们访问其他网站时,即使是在匿名的模式下,这些信息也可以帮助网站识别我们的身份。...
- 那些通用清除软件不曾注意的秘密_清理不常用的应用软件
-
系统清理就像卫生检查前的大扫除,即使你使出吃奶的劲儿把一切可能的地方都打扫过,还会留下边边角角的遗漏。随着大家电脑安全意识的提高,越来越多的朋友开始关注自己的电脑安全,也知道安装360系列软件来"武装...
- 「网络安全宣传周」这些安全上网小知识你要知道!
-
小布说:互联网改变了人们的衣食住行,但与之伴生的网络安全威胁也不容忽视。近些年来,风靡全球的勒索病毒、时有发生的电信诈骗、防不胜防的个人信息泄露时时刻刻都威胁着我们的生活。9月18日-24日是第四届...
- TypeScript 终极初学者指南_typescript 进阶
-
在过去的几年里TypeScript变得越来越流行,现在许多工作都要求开发人员了解TypeScript...
- jQuery知识一览_jquery的认识和使用
-
一、概览jQuery官网:https://jquery.com/jQuery是一个高效、轻量并且功能丰富的js库。核心在于查询query。...
- 我的第一个Electron应用_electronmy
-
hello,好久不见,最近笔者花了几天时间入门Electron,然后做了一个非常简单的应用,本文就来给各位分享一下过程,Electron大佬请随意~笔者开源了一个Web思维导图,虽然借助showSav...
- HTML5 之拖放(Drag 和 Drop)_html拖放api
-
简介拖放是一种常见的特性,即抓取对象以后拖到另一个位置。在HTML5中,拖放是标准的一部分,任何元素都能够拖放。先点击一个小例子:在用户开始拖动<p>元素时执行JavaScrip...
- 如何用JavaScript判断输入值是数字还是字母?
-
在日常开发中,我们有时候需要判断用户输入的是数字还是字母。本文将介绍如何用JavaScript实现这一功能。检查输入值是否是数字或字母...
- 图形编辑器开发:快捷键的管理_图形编辑工具
-
大家好,我是前端西瓜哥。...
- 浏览器原生剪贴板:原来它能这样读取用户截图!
-
当我们使用GitHub时,会发现Ctrl+V就能直接读取用户剪贴板图片进行粘贴,那么它是如何工作的?安全性如何?...