码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Bootstrap Blazor 开源UI库介绍-Table 虚拟滚动行


    合集 - Blazor(28)
    1.【转载】NETCore Bootstrap Admin 通用后台管理权限 [2]: Blazor 版本介绍2019-12-162.【转载】开源 一套 Blazor Server 端精致套件2020-05-303.【转载】Bootstrap Blazor 组件介绍 Table (一)自动生成列功能介绍2020-12-124.【转载】Bootstrap Blazor 组件介绍 Table (二)自定义模板列功能介绍2020-12-125.BootstrapBlazor 组件库介绍2020-12-026.BootstrapBlazor 组件库使用体验---Table篇2020-07-167.Bootstrap Blazor 使用模板创建项目2022-04-058.BootstrapBlazor-Table2022-04-039.BootstrapBlazor-ValidateForm 表单验证组件2022-04-0210.BootstrapBlazor 智能生成神器(一)AutoGenerateColumnAttribute 特性介绍2022-03-3111.BootstrapBlazor - EditorForm 表单组件(一)2022-03-2812.BootstrapBlazor--Input 组件2021-10-1313.BootstrapBlazor 模板安装2021-10-1314.【转载】Bootstrap Blazor 组件介绍 Table (三)列数据格式功能介绍2020-12-1215.BA & Blazor 技术交流群2022-10-26
    16.Bootstrap Blazor 开源UI库介绍-Table 虚拟滚动行2022-09-15
    17.Bootstrap Blazor AutoComplete 自动完成 组件2022-05-0618.Bootstrap Blazor Table 组件(四)自定义列生成2022-05-0519.Bootstrap Blazor Table 组件(三)智能生成2022-04-2720.Bootstrap Blazor 模板使用(一)Layout 组件2022-04-2621.Bootstrap Blazor Timer 计时器组件2022-04-2322.Bootstrap Blazor Cascader 级联选择组件2022-04-1723.Blazor 组件通讯2022-04-1724.Bootstrap Blazor 组件库 Row 布局组件(栅格系统)2022-04-1225.Bootstrap Blazor Table 组件(二)手动刷新组件数据2022-04-1026.Blazor 生命周期2022-04-1027.Bootstrap Blazor Modal 模态框组件2022-04-1028.Bootstrap Blazor 组件介绍2022-04-09
    收起

      今天我们来介绍一下 Bootstrap Blazor 中 Table 组件的虚拟滚动行,什么是虚拟滚动呢,我查到的解释是:只渲染可视区域的列表项,非可见区域的 完全不渲染,在滚动条滚动时动态更新列表项。

      然后很明显,在实际应用中不可能实现“非可见区域的 完全不渲染”,这样的体验效果太差了,下拉直接空白,所以一般会渲染3屏或者是3页数据,分别是当前页、上一页、下一页,当用户滚动到下一页的时候,将会自动加载再下一页,页面不会出现空白的情况,体验就非常爽了。

      有一小部分帅气(漂亮)的小伙伴可能就会问了,那一直滚动一直加载,后面不会很卡吗?答案是不会的,上面说到“只渲染可视区域的列表项,非可见区域的 完全不渲染”,而一般是渲染3屏或者3页数据,也就是说,除了这3个,其余的统统不渲染,通俗点来说就是看不见它就删掉它,这样在页面中,就永远最多只会渲染3页数据,除非你一行的数据量页极大,不然不会出现卡顿的情况,请小伙伴们放心!形象点请看下图:

      回来我们今天的主角-Bootstrap Blazor UI库 Table 组件虚拟滚动行,他是实现原理跟上面说的大体一致,当需要显示大量数据时通常采用分页加载数据,但是每次都要去点下一页有时候也是一件繁琐的事情,所以组件就支持虚拟滚动啦!

      功能的实现,其实是基于微软官方的 虚拟化组件,感兴趣的小伙伴可以去看看,传送门

      而在我们的BootstrapBlazor 的 Table 组件中,怎么去使用虚拟滚动呢,首先 需要设置 ScrollMode Height RowHeight PageItems 参数对虚拟滚动进行设置,并将 ScrollMode 设置成 "ScrollMode.Virtual" 我们直接看看代码

    razor

    复制代码
    <Table TItem = "Foo" IsBordered="true" IsStriped="true" Items="Items" ScrollMode="ScrollMode.Virtual">
        <TableColumns>
            <TableColumn @bind-Field="@context.DateTime" Width="180" />
            <TableColumn @bind-Field="@context.Name" />
            <TableColumn @bind-Field="@context.Address" Readonly="true" />
            <TableColumn @bind-Field="@context.Education" />
            <TableColumn @bind-Field="@context.Count" Editable="false" />
            <TableColumn @bind-Field="@context.Complete" />
        TableColumns>
    Table>
    复制代码

      上面的Table 组件的数据源是使用了Items,也就是说数据从开始的时候已经全部加载到了内存中,只是部将其全部渲染到前端页面而已,当数据量非常大的时候,这种方式明显是不适合的,会给服务端带来很大的压力,我们可以通过设置 Table 组件的 OnQueryAsync 回调,动态获取数据,用法上需要注意的一个点是,虚拟滚动的开始页码属性,不再是使用 options.PageIndex 而是使用 options.StartIndex

    razor

    复制代码
    <Table TItem = "Foo" IsBordered="true" IsStriped="true" ScrollMode="ScrollMode.Virtual" OnQueryAsync="OnQueryAsync">
       <TableColumns>
           <TableColumn @bind-Field="@context.DateTime" Width="180" />
           <TableColumn @bind-Field="@context.Name" />
           <TableColumn @bind-Field="@context.Address" Readonly="true" />
           <TableColumn @bind-Field="@context.Education" />
           <TableColumn @bind-Field="@context.Count" Editable="false" />
           <TableColumn @bind-Field="@context.Complete" />
       TableColumns>
    Table>
    复制代码

    razor.cs

    复制代码
    private async Task> OnQueryAsync(QueryPageOptions options)
    {
        await Task.Delay(200);
        var items = Items.Skip(options.StartIndex).Take(options.PageItems);
        return new QueryData()
        {
            Items = items,
            TotalCount = Items.Count
        };
    }
    复制代码

     为了模拟实际情况,特意加了200ms的延时,可以看到,当数据获取的期间,页面会渲染出 骨架屏 提升用户体验。

     

    原文链接:https://www.cnblogs.com/ysmc/p/16664945.html

    写在最后

    Bootstrap Blazor 官网地址:https://www.blazor.zone

      希望大佬们看到这篇文章,能给项目点个star支持下,感谢各位!

    star流程:

    1、访问点击项目链接:BootstrapBlazor   star

    2、点击star,如下图,即可完成star,关注项目不迷路:

     

    另外还有两个GVP项目,大佬们方便的话也点下star呗,非常感谢:

      BootstrapAdmin 项目地址:star
      https://gitee.com/LongbowEnterprise/BootstrapAdmin

      SliderCaptcha 项目地址:star
      https://gitee.com/LongbowEnterprise/SliderCaptcha

     

    交流群(QQ)欢迎加群讨论

           BA & Blazor ①(795206915)          BA & Blazor ②(675147445)

  • 相关阅读:
    【Spring】bean的基础配置
    anaconda安装及配置+pytorch安装与配置(自用笔记)
    项目上线就炸,这谁受得了
    [Python从零到壹] 五十三.图像增强及运算篇之直方图均衡化处理
    百度集团副总裁吴甜解读跨模态大模型技术创新,发布AI作画神器文心·一格
    【Redis】Redis与SSM整合&Redis注解式缓存&Redis解决缓存问题
    mysql8.0版本的 utf8mb4 格式数据不能移植到 mysql1.0版本上
    【TES600】青翼科技基于XC7K325T与TMS320C6678的通用信号处理平台
    html+css+js实现简单的交互效果
    # 从浅入深 学习 SpringCloud 微服务架构(六)Feign(3)
  • 原文地址:https://www.cnblogs.com/ysmc/p/16664945.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号