0

0

C# Blazor组件虚拟化方法 C#如何使用Virtualize组件高效显示大量数据

煙雲

煙雲

发布时间:2026-03-09 12:45:12

|

871人浏览过

|

来源于php中文网

原创

virtualize 组件比普通 foreach 快,因为它只渲染可视区域及缓冲区内的条目并复用 dom,而 foreach 会为全部数据生成 dom 导致卡顿;要求 items 为 ilist 或支持 getitemsasync 的分页服务,且需指定 itemsize。

c# blazor组件虚拟化方法 c#如何使用virtualize组件高效显示大量数据

Virtualize 组件为什么比普通 foreach 快

因为 Virtualize 不会一次性渲染全部数据项,只渲染当前可视区域(加少量缓冲)的条目,滚动时动态复用 DOM 元素。而 @foreach 会为每个数据项生成完整 DOM 节点,10 万条数据直接卡死浏览器。

关键前提是:数据源必须支持按索引随机访问(IList<t></t> 或实现 GetItemAsync 的分页服务),不能是纯 IEnumerable<t></t> 流式数据。

基础用法:绑定 IList 并设置 itemSize

最常用场景是本地内存列表,比如 List<product></product>。必须显式指定 itemSize(像素高度),否则无法计算可视范围:

<Virtualize Items="@products" ItemSize="48">
    <ItemContent>
        <div class="product-item">@context.Name - @context.Price</div>
    </ItemContent>
</Virtualize>
  • Items 必须是 IList<t></t>,传 products.AsEnumerable() 会编译通过但运行时报 InvalidOperationException: Items must be an IList<t></t>
  • ItemSize 是估算值,不精确会导致滚动抖动或空白;若行高不固定,需改用 GroupItemSize + 自定义逻辑,或放弃虚拟化
  • 组件内部会调用 Countindexer,所以 Count 应为 O(1),避免每次取长度都遍历

异步加载:用 GetItemsAsync 接口对接后端分页

当数据量极大或需服务端过滤时,用 GetItemsAsync 替代 Items,由 Blazor 按需拉取片段:

面多多
面多多

面试鸭推出的AI面试训练平台

下载
<Virtualize TItem="Order" 
          ItemsProvider="@LoadOrders"
          ItemSize="60">
    <ItemContent>
        <div>#@context.OrderId - @context.Status</div>
    </ItemContent>
</Virtualize>

LoadOrders 方法签名必须为:Func<itemsproviderrequest valuetask>>></itemsproviderrequest>

  • 每次滚动触发请求时,ItemsProviderRequest 包含 StartIndexCount,你需据此查数据库(如 OFFSET @start ROWS FETCH NEXT @count ROWS ONLY
  • 返回的 ItemsProviderResult<titem></titem> 必须包含 ItemsHasMoreItems;漏设 HasMoreItems = false 会导致无限加载假象
  • 注意并发:快速滚动可能触发多个请求,建议在 LoadOrders 内做防抖或取消前序 CancellationToken

常见卡顿和空白问题排查

虚拟化失效往往不是代码写错,而是隐性约束被打破:

  • 父容器未设固定高度或 max-heightVirtualize 无法判断可视区域 → 页面必须给外层 <div style="height: 500px"> 包裹<li>子元素用了 <code>position: absolutetransform,破坏了默认的流式布局尺寸计算 → 避免在 ItemContent 内做绝对定位
  • 过度使用 @key 或复杂组件状态(如内嵌 EditForm),导致重渲染开销上升 → 单个 ItemContent 内保持轻量,表单操作建议抽离到弹窗
  • Chrome DevTools 中看到大量 blazor-error-ui 提示“JS interop timeout” → 检查 GetItemsAsync 是否阻塞或超时,服务端响应应控制在 200ms 内
  • 真正难调的是混合场景:既要服务端分页,又要客户端搜索过滤。这时候得自己实现带缓存的 ItemsProvider,把已拉取的片段存在内存里,避免重复请求 —— 这部分没有现成组件,得手写逻辑。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1051

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

830

2023.11.06

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1051

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

830

2023.11.06

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

245

2025.12.04

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

472

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

375

2023.10.25

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

59

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
c语言项目php解释器源码分析探索
c语言项目php解释器源码分析探索

共7课时 | 0.4万人学习

光速学会docker容器
光速学会docker容器

共33课时 | 2万人学习

PHP WEB 项目实战
PHP WEB 项目实战

共16课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号