Blazor Virtualize 组件通过虚拟滚动仅渲染可视区域项,避免全量 DOM 创建,解决长列表卡顿等问题;需设固定高度容器、用 Items 或 ItemsProvider 绑定数据源,并可配置 OverscanCount 和 Placeholder 优化体验。

Blazor 的 Virtualize 组件通过“虚拟滚动”只渲染可视区域内的项,大幅减少 DOM 元素数量,解决长列表卡顿、内存占用高、首次加载慢等问题。关键不是“全量渲染后隐藏”,而是根本不去创建不可见项的 DOM。
基础用法:替换 @foreach
把原来遍历集合的 @foreach 替换成 ,并指定数据源和每项模板:
用 Items="@items" 绑定可枚举集合(支持 IEnumerable、IQueryable、Array)用 ItemContent 模板定义单个条目结构,内部用 @context 访问当前项容器需有固定高度(如 style="height: 500px;"),否则无法计算可视区域
示例:
@product.Name - @product.Price
提升性能:配合分页式数据源
当数据量极大(如百万级),不建议一次性加载全部到内存。应让 ItemsProvider 按需拉取:
设置 ItemsProvider="@LoadProductsAsync",替代 Items方法签名必须是 ValueTask> Func>>从 request.StartIndex 和 request.Count 算出数据库分页参数(如 OFFSET ... LIMIT ...)返回 new ItemsProviderResult(data, totalItemCount),其中 totalItemCount 用于滚动条比例计算
优化体验:设置占位与缓冲区
默认只渲染刚好可见的项,快速滚动时可能白屏或闪烁。加两个属性改善:
OverscanCount:额外多渲染几项(上下各 N 行),比如设为 3 可让滚动更顺滑Placeholder:在数据加载中显示骨架屏,避免空白等待
示例:
...
注意细节:避免常见坑
不支持嵌套 Virtualize 或在 flex/grid 容器中无显式高度;确保父容器有 overflow-y: auto 或由外层滚动控制;ItemsProvider 中不要做耗时同步操作;若项高度不一致,虚拟化仍能工作,但滚动条位置可能不够精确(此时可配合 ItemSize 预估平均高度提升精度)。
基本上就这些。用对 Virtualize,万级列表也能丝滑滚动,不复杂但容易忽略高度和数据源模式这两个关键点。
以上就是Blazor 怎么使用 Virtualize 组件优化长列表的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1442957.html
微信扫一扫
支付宝扫一扫