Maison  >  Article  >  interface Web  >  Une brève analyse de la fonction de génération automatique de colonnes du composant Table dans Bootstrap Blazor

Une brève analyse de la fonction de génération automatique de colonnes du composant Table dans Bootstrap Blazor

青灯夜游
青灯夜游avant
2022-02-28 11:01:363849parcourir

La colonne Bootstrap suivante vous fera comprendre le composant Table dans Bootstrap Blazor et présentera la fonction de génération automatique de colonnes du composant Table. J'espère qu'elle sera utile à tout le monde !

Une brève analyse de la fonction de génération automatique de colonnes du composant Table dans Bootstrap Blazor

Bootstrap Blazor est une bibliothèque de composants d'interface utilisateur de niveau entreprise adaptée aux appareils mobiles et prenant en charge divers navigateurs grand public. Elle a été utilisée dans plusieurs projets de livraison. Cet ensemble de composants peut raccourcir considérablement le cycle de développement et réduire les coûts de développement. Plus de 70 composants ont été développés et conditionnés jusqu'à présent.

  • L'adresse open source de Gitee est : https://gitee.com/LongbowEnterprise/BootstrapBlazor

  • L'adresse open source de Github est : https://github.com/ArgoZhang/BootstrapBlazor

  • Site Web de démonstration en ligne : https ://www.blazor.zone

Table devrait être le composant central du développement d'un site Web de gestion. De nombreuses fonctions peuvent être dérivées de Table, car. Cet ensemble de composants n'a presque aucune publicité, donc peu de gens le savent. Cependant, de nombreux amis ont utilisé d'autres projets Blazor open source et ont constaté que le composant Table ne pouvait pas être utilisé du tout. Table 应该是做管理型网站开发的核心组件了,通过 Table 可以衍生出非常多的功能,由于这套组件几乎没有宣传,导致知道的人不是很多,但是很多小伙伴都是使用了其他一些开源 blazor 项目后发现 Table 组件根本无法使用。

  • 加载数据太卡
  • 功能缺失太多

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

自动生成列功能

使用 Table 组件时大多数组件都是要求用户输入显示那些列,这样会在 razor 文件中增加大量列相关信息,如下所示

<TableColumn @bind-Field="@context.DateTime" Width="180" />
<TableColumn @bind-Field="@context.Name" />
<TableColumn @bind-Field="@context.Address" />
<TableColumn @bind-Field="@context.Education" />
<TableColumn @bind-Field="@context.Count" />
<TableColumn @bind-Field="@context.Complete">

如果一个实体类属性太多时。这里书写起来就会篇幅非常长,BootstrapBlazor 组件库的 Table 组件有一个属性 AutoGenerateColumns ,当设置其值为 true 时,会根据绑定模型的属性进行自动生成列信息,为开发人员节约了大量的代码,先看示例

<Table TItem="BindItem" IsStriped="true" IsBordered="true" IsMultipleSelect="true"
            ShowToolbar="true" ShowExtendButtons="true" AutoGenerateColumns="true"
            OnQueryAsync="@OnEditQueryAsync" OnResetSearchAsync="@OnResetSearchAsync"
            OnSaveAsync="@OnSaveAsync" OnDeleteAsync="@OnDeleteAsync">
</Table>

怎么样?通过这一行代码就完成了表格的全自动生成,并且提供了增、删、改、查、过滤、排序等等全部功能。效果图如下

是不是有一些心动,这么少的代码居然可以实现这么多功能?没错!用 BootstrapBlazor 组件库的 Table 组件开发就是这么简单。

划重点

使用 Table 组件 UI 层面的基本操作均已经封装到组件功能中,开发人员只需要将精力转移到数据库的操作上去,如例子中的

  • OnQueryAsync 数据查询方法
  • OnSaveAsync 数据保存方法(内部自动判断主键执行插入或者更新操作)
  • OnDeleteAsync 数据删除方法 (可自行进行真实删除或者标记删除操作)
  • OnResetSearchAsync 重置搜索方法

实现原理

Table 组件为泛型组件,通过 TItem 设定绑定模型类型为 BindItem 实体类,在这个实体类中通过 AutoGenerateColumnAttribute

    Le chargement des données est trop lent

    Il y a trop de fonctions manquantes

    Donc, à partir d'aujourd'hui, je présenterai officiellement les performances explosives et le fonctionnement simple de BootstrapBlazor, le composant roi le plus puissant de la bibliothèque de composants Table, car il y a tellement de fonctions, il y a près de 60 fonctions dans le site Web actuel qui sont nécessaires au combat réel. Nous les présenterons une par une dans la période suivante

    🎜🎜<. span style="font -size: 18px;">Fonction de colonne générée automatiquement🎜🎜🎜Lors de l'utilisation du composant Table, la plupart des composants nécessitent que l'utilisateur saisisse les colonnes à afficher, lesquelles sera affiché dans razor code> Ajoutez un grand nombre d'informations liées aux colonnes au fichier, comme indiqué ci-dessous🎜<pre class="brush:html;toolbar:false;">[AttributeUsage(AttributeTargets.Property)] public class AutoGenerateColumnAttribute : Attribute, ITableColumn { /// &lt;summary&gt; /// 获得/设置 显示顺序 /// &lt;/summary&gt; public int Order { get; set; } /// &lt;summary&gt; /// 获得/设置 是否忽略 默认为 false 不忽略 /// &lt;/summary&gt; public bool Ignore { get; set; } /// &lt;summary&gt; /// 获得/设置 当前列是否可编辑 默认为 true 当设置为 false 时自动生成编辑 UI 不生成此列 /// &lt;/summary&gt; public bool Editable { get; set; } = true; /// &lt;summary&gt; /// 获得/设置 当前列编辑时是否只读 默认为 false /// &lt;/summary&gt; public bool Readonly { get; set; } /// &lt;summary&gt; /// 获得/设置 是否允许排序 默认为 false /// &lt;/summary&gt; public bool Sortable { get; set; } /// &lt;summary&gt; /// 获得/设置 是否为默认排序列 默认为 false /// &lt;/summary&gt; public bool DefaultSort { get; set; } /// &lt;summary&gt; /// 获得/设置 是否为默认排序规则 默认为 SortOrder.Unset /// &lt;/summary&gt; public SortOrder DefaultSortOrder { get; set; } /// &lt;summary&gt; /// 获得/设置 是否允许过滤数据 默认为 false /// &lt;/summary&gt; public bool Filterable { get; set; } /// &lt;summary&gt; /// 获得/设置 是否参与搜索 默认为 false /// &lt;/summary&gt; public bool Searchable { get; set; } /// &lt;summary&gt; /// 获得/设置 列宽 /// &lt;/summary&gt; public int? Width { get; set; } /// &lt;summary&gt; /// 获得/设置 是否固定本列 默认 false 不固定 /// &lt;/summary&gt; public bool Fixed { get; set; } /// &lt;summary&gt; /// 获得/设置 列是否显示 默认为 true 可见的 /// &lt;/summary&gt; public bool Visible { get; set; } = true; /// &lt;summary&gt; /// 获得/设置 本列是否允许换行 默认为 false /// &lt;/summary&gt; public bool AllowTextWrap { get; set; } /// &lt;summary&gt; /// 获得/设置 本列文本超出省略 默认为 false /// &lt;/summary&gt; public bool TextEllipsis { get; set; } /// &lt;summary&gt; /// 获得/设置 列 td 自定义样式 默认为 null 未设置 /// &lt;/summary&gt; public string? CssClass { get; set; } /// &lt;summary&gt; /// 获得/设置 显示节点阈值 默认值 BreakPoint.None 未设置 /// &lt;/summary&gt; public BreakPoint ShownWithBreakPoint { get; set; } /// &lt;summary&gt; /// 获得/设置 格式化字符串 如时间类型设置 yyyy-MM-dd /// &lt;/summary&gt; public string? FormatString { get; set; } /// &lt;summary&gt; /// 获得/设置 文字对齐方式 默认为 Alignment.None /// &lt;/summary&gt; public Alignment Align { get; set; } /// &lt;summary&gt; /// 获得/设置 字段鼠标悬停提示 /// &lt;/summary&gt; public bool ShowTips { get; set; } /// &lt;summary&gt; /// 获得/设置 列格式化回调委托 /// &lt;/summary&gt; public Func&lt;object?, Task&lt;string&gt;&gt;? Formatter { get; set; } /// &lt;summary&gt; /// 获得/设置 编辑模板 /// &lt;/summary&gt; public RenderFragment&lt;object&gt;? EditTemplate { get; set; } /// &lt;summary&gt; /// 获得/设置 显示模板 /// &lt;/summary&gt; public RenderFragment&lt;object&gt;? Template { get; set; } /// &lt;summary&gt; /// 获得/设置 搜索模板 /// &lt;/summary&gt; public RenderFragment&lt;object&gt;? SearchTemplate { get; set; } /// &lt;summary&gt; /// 获得/设置 过滤模板 /// &lt;/summary&gt; public RenderFragment? FilterTemplate { get; set; } /// &lt;summary&gt; /// 获得/设置 列头显示文字未设置时显示字段名称 /// &lt;/summary&gt; public string? Text { get; set; } }</pre>🎜S'il y a trop d'attributs d'une classe d'entité. Ce serait très long à écrire ici. Le composant <code>Table de la bibliothèque de composants BootstrapBlazor a une propriété AutoGenerateColumns lorsque sa valeur est définie sur <. code>true , les informations sur les colonnes seront automatiquement générées en fonction des attributs du modèle lié, ce qui permettra aux développeurs d'économiser beaucoup de code. Que diriez-vous de regarder d'abord l'exemple 🎜rrreee🎜 ? Grâce à cette ligne de code, le tableau est généré de manière entièrement automatique et toutes les fonctions telles que l'ajout, la suppression, la modification, la vérification, le filtrage, le tri, etc. sont fournies. Le rendu est le suivant🎜🎜🎜 🎜Oui N'êtes-vous pas un peu enthousiasmé par le fait que si peu de code puisse réellement réaliser autant de fonctions ? C'est exact! Le développement à l'aide du composant Table de la bibliothèque de composants BootstrapBlazor est si simple. 🎜🎜🎜Emphasis🎜🎜🎜Utilisez le composant Table. Les opérations de base au niveau de l'interface utilisateur ont été encapsulées dans les fonctions du composant. Les développeurs n'ont qu'à transférer leur énergie vers les opérations de base de données, comme dans l'exemple 🎜🎜OnQueryAsync Méthode de requête de données 🎜🎜OnSaveAsync Méthode de sauvegarde des données (détermine automatiquement en interne la clé primaire pour effectuer les opérations d'insertion ou de mise à jour) 🎜🎜OnDeleteAsync Méthode de suppression des données (vous pouvez effectuer une suppression réelle ou marquer la suppression par vous-même) 🎜🎜OnResetSearchAsync Réinitialiser la méthode de recherche 🎜🎜🎜🎜Principe de mise en œuvre🎜 🎜🎜Le composant Table est un composant générique et le type de modèle de liaison est défini sur la classe d'entité BindItem via TItem. classe d'entité, passez AutoGenerateColumnAttribute définit les règles de génération automatique des colonnes. Les paramètres spécifiques sont les suivants : 🎜rrreee🎜Il existe un grand nombre de paramètres qui peuvent être limités, il suffit de regarder les commentaires pour. savoir. Pour plus de documentation, veuillez consulter le document de démonstration en ligne https://www.blazor.zone/tables/column🎜🎜Pour plus de connaissances sur le bootstrap, veuillez visiter : 🎜tutoriel bootstrap🎜 ! ! 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer