BootstrapBlazor 之王者组件 Table

强大的表格组件

Gitee 开源地址为:

https://gitee.com/LongbowEnterprise/BootstrapBlazor

Github 开源地址为:

https://github.com/ArgoZhang/BootstrapBlazor

在线演示网站:

https://www.blazor.zone

1、前言

Table(表格)组件应该是做管理型网站开发的核心组件了,通过 Table 可以衍生出非常多的功能,由于这套组件几乎没有宣传,导致知道的人不是很多,但是很多小伙伴都是使用了其他一些开源 blazor 项目后发现 Table 组件根本无法使用。

  • 加载数据太卡

  • 功能缺失太多

那么从今天开始正式介绍一下性能爆炸,操作简单的 BootstrapBlazor 组件库中的最强王者组件 Table,由于功能实在是太多,仅示例目前网站中就有近 60 个各种实战中需要的功能。

表格文档:

https://www.blazor.zone/tables

2、一句代码生成表格

BootstrapBlazor 组件库的 Table 组件有一个属性 AutoGenerateColumns,当设置其值为 true 时,会根据绑定模型的属性进行自动生成列信息,为开发人员节约了大量的代码,先看示例代码:

备注:安装预览版的 BootstrapBlazor 才有 AutoGenerateColumns 属性

index.razor 文件

<Table TItem="UserInfo" Items="@UserInfoList" AutoGenerateColumns="true" />
@code {//模拟生成数据private static readonly Random random = new Random();protected static List<UserInfo> GenerateUserInfos() => new List<UserInfo>(Enumerable.Range(1, 10).Select(i => new UserInfo(){Id = i,Name = $"张三 {i:d4}",Address = $"上海市普陀区金沙江路 {random.Next(1000, 2000)} 弄",Age = random.Next(20, 50),Mobile = "1301234" + random.Next(1000, 9999)}));protected static IEnumerable<UserInfo> UserInfoList { get; } = GenerateUserInfos();
}

UserInfo.cs

public class UserInfo
{public int Id { get; set; }public string Name { get; set; }public string Address { get; set; }public int Age { get; set; }public string Mobile { get; set; }
}

再来看看效果图如何:

你没看错,就这么很简单的几句代码生成了一个可展示的表格。

下巴掉地上了吧,先收起来,这么简单?

下面再加入一些表单功能试试看,将 index.razor 代码修改如下:

<Table TItem="UserInfo" Items="@UserInfoList" AutoGenerateColumns="true"ShowToolbar="true" />

仅仅加入了 ShowToolbar="true" 这句代码而已。截个图瞅瞅:

工具栏有了!但是点击按钮右下角提示需要实现保存数据方法。我们再来试试看:

<Table TItem="UserInfo" Items="@UserInfoList" AutoGenerateColumns="true"ShowToolbar="true"IsMultipleSelect="true"     //--> 开启多选框,用于编辑删除选择数据OnSaveAsync="@OnSaveAsync"  //--> 提供保存数据方法/>

index.razor@code 大括号里加入一个 OnSaveAsync 方法:

//这里只是演示,没有增加修改数据
protected Task<bool> OnSaveAsync(UserInfo userInfo)
{return Task.FromResult(true);
}

这次也是仅仅加入了四五行代码而已。截个图瞅瞅:

新增数据对话框有了!

编辑对话框有了!

删除操作有了!

到这里我相信大家已经有了跃跃欲试的感觉,那就别客气,动手吧~~

3、表格美化:

1) 加入斑马纹效果

加入属性:IsStriped="true" 即可

代码看起来是这样的:

<Table TItem="UserInfo" Items="@UserInfoList" AutoGenerateColumns="true"ShowToolbar="true"IsMultipleSelect="true"OnSaveAsync="@OnSaveAsync"IsStriped="true"/>

2) 加入边框

加入属性:IsBordered="true" 即可

代码看起来是这样的:

<Table TItem="UserInfo" Items="@UserInfoList" AutoGenerateColumns="true"ShowToolbar="true"IsMultipleSelect="true"OnSaveAsync="@OnSaveAsync"IsStriped="true"IsBordered="true"/>

3) 紧凑型表格

加入属性:TableSize="TableSize.Compact" 即可。

代码太简单就不展示了,免得有人骂我~~~(手动狗头)

现在的样子小而美~~

4) 生成列属性更改

上面的截图大家都看到了,标题都是类属性名,自动生成的,(心里暗骂这TM交给客户不骂死我),别着急,将 Display 特性加入到 UserInfo 类属性上就可以自定义了。瞅瞅代码:

using System.ComponentModel;
public class UserInfo
{[DisplayName("自动编号")]public int Id { get; set; }[DisplayName("名称")]public string Name { get; set; }[DisplayName("地址")]public string Address { get; set; }[DisplayName("年龄")]public int Age { get; set; }[DisplayName("手机号")]public string Mobile { get; set; }
}

还有很多很多可以自定义的东西,比如,每一列的格式,排序等等等待您的探索,这一期就到这里。以后还会继续介绍更多组件,更多有意思的玩法。

希望您会喜欢,觉得有意思,加个关注,点个再看,再去 github 上点个⭐。

推荐阅读:

  • 企业级精致 Blazor 套件 BootstrapBlazor 介绍

  • [推荐]大量 Blazor 学习资源(一)

  • [推荐]大量 Blazor 学习资源(二)

  • [推荐]大量 Blazor 学习资源(三)

  • WPF开源控件扩展库 - MaterialDesignExtensions

  • YiShaAdmin :快速后台开发框架,赚钱就靠它了!

开发者精选资讯
 每日为您推荐开发精选资讯

长按二维码
关注 「开发者精选资讯」 公众号

好文章,我在看 ❤️ 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/306548.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据结构——最大堆最小堆

定义&#xff1a; 最大堆和最小堆都是一棵完全二叉树。 最大堆&#xff1a;是指根节点的关键字值是堆中的最大关键字值&#xff0c;且每个节点若有儿子节点&#xff0c;其关键字值都不小于其儿子节点的关键字值。 最小堆&#xff1a;是指根节点的关键字值是堆中的最小关键字值…

EntityFramework Core 健康检查

【导读】.NET Core提供对应方法可进行健康检查&#xff0c;那么在EF Core中是否也提供了相应的方式呢&#xff1f;EF Core 2.2&#xff08;包含2.2&#xff09;版本提供了针对上下文的健康检查&#xff0c;接下来我们直接利用.NET 5.0版本进行演示EntityFramework Core 5.0健康…

算法设计与分析——分支限界法——布线问题

印刷电路板将布线区域划分成nm个方格如图a所示。精确的电路布线问题要求确定连接方格a的中点到方格b的中点的最短布线方案。在布线时&#xff0c;电路只能沿直线或直角布线&#xff0c;如图b所示。为了避免线路相交&#xff0c;已布了线的方格做了封锁标记&#xff0c;其它线路…

我是如何把 Java 项目移植到 .NET 5.0 的

伴随着 IP 位置库 的上线&#xff0c;笔者的“童年梦想”又成真了一个。为了分发这份来之不易的数据库&#xff0c;笔者找到了 ip2region 项目。该项目提供了一种体积小且查询速度极快的离线IP位置数据库文件格式&#xff0c;同时提供了多种语言支持的查询客户端。但 ip2region…

qt制作一个画板_如何直接用Sketch制作动画|Sketch插件|

本期的sketch插件来为大家讲解如何制作动画&#xff0c;看来看看马克笔设计留学的MUzi老师的教程吧&#xff01;安装1.下载并解压 Anima Tookit.ziphttps://timeline.animaapp.com/2.双击 Anima Tookit.sketchplugin 完成安装使用1.执行 Plugins > Anima Tookit > Show/H…

算法设计与分析——动态规划——最大字段和问题

动态规划解决问题是自底向上。原问题的规模是n个元 素。这n个元素不好考虑&#xff0c;我们先考虑n-1个元素&#xff0c;这样还不好考 虑&#xff0c;我们考虑n-2个元素&#xff0c;这样依次递减&#xff0c;最后问题规模变成一个 元素。但是我们发现&#xff0c;在递减的过程中…

如何在 Asp.Net Core 中 管理敏感数据

译文链接&#xff1a;https://www.infoworld.com/article/3576292/how-to-work-with-user-secrets-in-asp-net-core.html在应用程序开发时&#xff0c;你肯定会有一些特别需要保护的数据&#xff0c;这些数据通常是非常机密的&#xff0c;敏感的&#xff0c;禁止和别人共享&…

C#开源项目:SiMay远程控制管理系统

C#开源项目&#xff1a;SiMay远程控制管理系统Gitee仓库截图下方基于原项目仓库readme系统介绍SiMay远程控制管理系统是一个Windows远程控制系统&#xff0c;底层基于IOCP的异步通信模型&#xff0c;能对海量客户端实时监控&#xff0c;目前功能已实现&#xff1a;逐行扫描远程…

算法设计与分析——回溯法——01背包问题

//0-1背包问题 回溯法求解 #include<bits/stdc.h> #include <iostream>using namespace std; template<class Typew,class Typep> class Knap {public:Typep Bound(int i);void Backtrack(int i);Typew c; //背包容量int n; //物品数Typew *w; //物品重量数…

排列组合思维导图_排列组合——排列数专题

在上篇关于排列组合主要考点的介绍中&#xff0c;正男老师提到&#xff1a;排列组合考点通常可以拆分为排列数考点和组合数考点。排列数考点相关试题可以细分为2类&#xff0c;分别为&#xff1a;穷举问题和限制条件问题。本期正男老师就从近六年内的5道涉及排列数考点的真题入…

高级的说服,从不讲道理

大家好&#xff0c;我是Z哥。你会发现有一些人&#xff0c;他们好像说话从来都没有说服过别人&#xff0c;天天被别人牵着鼻子走。但有些人一说的话你就觉得特别对&#xff0c;就应该按照他说的办。很明显&#xff0c;我们都希望自己是后者。能不能说服人&#xff0c;不管在生活…

算法设计与分析——分支限界法——n皇后问题

一、问题描述 问题描述&#xff1a;在nn格的棋盘上放置彼此不受攻击的n个皇后。按照国际象棋的规则&#xff0c;皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。n皇后问题等价于在n*n的棋盘上放置n个皇后&#xff0c;任何2个皇后不放在同一行或同一列或同一斜线上。 …

IdentityServer4系列 | 授权码模式

一、前言在上一篇关于简化模式中&#xff0c;通过客户端以浏览器的形式请求「IdentityServer」服务获取访问令牌&#xff0c;从而请求获取受保护的资源&#xff0c;但由于token携带在url中&#xff0c;安全性方面不能保证。因此&#xff0c;我们可以考虑通过其他方式来解决这个…

算法设计与分析——算法思想总结

算法设计与分析 1、分治法 分治法的基本思想是将一个规模为n的问题分解为k个规模较小的子问题&#xff0c;这些子问题相互独立且与原问题相同。递归的解这些子问题&#xff0c;然后将各子问题的解合并得到原问题的解。 分治法所能解决的问题一般具有以下几个特征&#xff1a…

pearson相关系数_Pearson(皮尔逊)相关系数

由于使用的统计相关系数比较频繁&#xff0c;所以这里就利用几篇文章简单介绍一下这些系数。相关系数&#xff1a;考察两个事物(在数据里我们称之为变量)之间的相关程度。如果有两个变量&#xff1a;X、Y&#xff0c;最终计算出的相关系数的含义可以有如下理解&#xff1a;(1)、…

聊一聊ABP vNext的模块化系统

官网&#xff1a;https://abp.io/开源&#xff1a;https://github.com/abpframework/abp EasyAbp&#xff1a;https://easyabp.io/Abp 模块&#xff1a;https://abp.io/packages模块化系统ABP vNext 的世界观在 Abp vNext 框架里面&#xff0c;模块系统是整个框架的基石&#x…

双离合档把上按钮作用_英特尔展示双屏幕概念笔记本:带有双铰链

本文转自&#xff1a;IT之家作者&#xff1a;嗜橙近日&#xff0c;英特尔在位于圣克拉拉总部深处的一个半秘密实验室里&#xff0c;公布了配备两个屏幕的概念笔记本电脑。在近日的台北电脑展上&#xff0c;华硕发布了双屏笔记本&#xff1b;不久之后&#xff0c;英特尔也公布了…

浏览器眼中的0

0作为一个特殊的符号&#xff0c;经常会跟浏览器打交道&#xff0c;在不同的场景下&#xff0c;0代表的意思不尽相同&#xff0c;因此浏览器眼中的0不一定就是符合人们感官上的认识&#xff0c;那究竟浏览器会怎么对待它呢&#xff0c;今天我们就来探究一下各种场景中0的含义及…

剑指offer——01二维数组中的查找.

class Solution { public:bool Find(int target, vector<vector<int> > array) {int m array.size();//得到该二维数组的行数if(m0) return false;//如果行数为0则直接退出int n array[0].size();//得到该二维数组的列数if(n0) return false;//如果列数为0则直接退…

GraphQL:验证与授权

GraphQL 既是一种用于 API 的查询语言也是一个满足你数据查询的运行时。GraphQL 对你的 API 中的数据提供了一套易于理解的完整描述&#xff0c;使得客户端能够准确地获得它需要的数据&#xff0c;而且没有任何冗余&#xff0c;也让 API 更容易地随着时间推移而演进&#xff0c…