recherche
Maisoninterface WebTutoriel d'amorçageUne brève analyse de la fonction de génération automatique de colonnes du composant Table dans Bootstrap Blazor

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:php;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
Bootstrap: faciliter la conception WebBootstrap: faciliter la conception WebApr 13, 2025 am 12:10 AM

Qu'est-ce qui rend la conception Web plus facile, c'est bootstrap? Ses composants prédéfinis, sa conception réactive et son riche soutien communautaire. 1) Les bibliothèques et styles de composants prédéfinis permettent aux développeurs d'éviter d'écrire du code CSS complexe; 2) Le système de grille intégré simplifie la création de dispositions réactives; 3) Le soutien communautaire fournit des ressources et des solutions riches.

Impact de bootstrap: accélérer le développement WebImpact de bootstrap: accélérer le développement WebApr 12, 2025 am 12:05 AM

Bootstrap accélère le développement Web et en fournissant des styles et des composants prédéfinis, les développeurs peuvent rapidement créer des sites Web réactifs. 1) Il raccourcit le temps de développement, comme l'achèvement de la disposition de base en quelques jours dans le projet. 2) Grâce aux variables et mixins SASS, Bootstrap permet aux styles personnalisés de répondre aux besoins spécifiques. 3) L'utilisation de la version CDN peut optimiser les performances et améliorer la vitesse de chargement.

Comprendre le bootstrap: concepts et fonctionnalités de baseComprendre le bootstrap: concepts et fonctionnalités de baseApr 11, 2025 am 12:01 AM

Bootstrap est un cadre frontal open source, et sa fonction principale est d'aider les développeurs à créer rapidement des sites Web réactifs. 1) Il fournit des classes CSS prédéfinies et des plug-ins JavaScript pour faciliter la mise en œuvre d'effets d'interface utilisateur complexes. 2) Le principe de travail de Bootstrap s'appuie sur ses composants CSS et JavaScript pour réaliser une conception réactive à travers les requêtes multimédias. 3) Les exemples d'utilisation incluent l'utilisation de base, tels que la création de boutons et l'utilisation avancée, telles que les styles personnalisés. 4) Les erreurs courantes incluent la fausse orthographe des noms de classe et l'introduction incorrecte de fichiers. Il est recommandé d'utiliser des outils de développeur de navigateur pour déboguer. 5) L'optimisation des performances peut être obtenue grâce à des outils de construction personnalisés, les meilleures pratiques incluent prédéfinies à l'aide de HTML sémantique et de bootstrap

Bootstrap Deep Dive: Conception réactive et techniques de mise en page avancéesBootstrap Deep Dive: Conception réactive et techniques de mise en page avancéesApr 10, 2025 am 09:35 AM

Bootstrap implémente la conception réactive via des systèmes de grille et des requêtes multimédias, ce qui rend le site Web adapté à différents appareils. 1. Utilisez une classe prédéfinie (comme Col-SM-6) pour définir la largeur de la colonne. 2. Le système de grille est basé sur 12 colonnes, et il est nécessaire de noter que la somme ne dépasse pas 12. 3. Utilisez des points d'arrêt (tels que SM, MD, LG) pour définir la disposition sous différentes tailles d'écran.

Questions d'entrevue bootstrap: atterrir votre travail frontal de rêveQuestions d'entrevue bootstrap: atterrir votre travail frontal de rêveApr 09, 2025 am 12:14 AM

Bootstrap est un cadre frontal open source pour le développement rapide de sites Web et d'applications réactifs. 1. Il offre les avantages de la conception réactive, des composants d'interface utilisateur cohérents et du développement rapide. 2. Le système de grille utilise la disposition Flexbox, basée sur une structure à 12 colonnes, et est implémentée via des classes telles que .Container, .Row et .Col-SM-6. 3. Les styles personnalisés peuvent être implémentés en modifiant les variables SASS ou en écrasant CSS. 4. Les composants JavaScript couramment utilisés comprennent des boîtes modales, des diagrammes de carrousel et un pliage. 5. Les performances d'optimisation peuvent être obtenues en chargeant uniquement les composants nécessaires, en utilisant CDN et en compressant des fichiers de fusion.

Bootstrap & JavaScript Integration: fonctionnalités dynamiques et fonctionnalitéBootstrap & JavaScript Integration: fonctionnalités dynamiques et fonctionnalitéApr 08, 2025 am 12:10 AM

Bootstrap et JavaScript peuvent être intégrés de manière transparente pour donner aux pages Web des fonctionnalités dynamiques. 1) Utilisez JavaScript pour manipuler des composants bootstrap, tels que les boîtes modales et les barres de navigation. 2) Assurez-vous que JQuery charge correctement et évitez les problèmes d'intégration courants. 3) Atteignez l'interaction complexe des utilisateurs et les effets dynamiques grâce à la surveillance des événements et aux opérations DOM.

Comment obtenir la barre de recherche bootstrapComment obtenir la barre de recherche bootstrapApr 07, 2025 pm 03:33 PM

Comment utiliser Bootstrap pour obtenir la valeur de la barre de recherche: détermine l'ID ou le nom de la barre de recherche. Utilisez JavaScript pour obtenir des éléments DOM. Obtient la valeur de l'élément. Effectuer les actions requises.

Comment insérer des photos sur bootstrapComment insérer des photos sur bootstrapApr 07, 2025 pm 03:30 PM

Il existe plusieurs façons d'insérer des images dans Bootstrap: insérer directement les images, en utilisant la balise HTML IMG. Avec le composant d'image bootstrap, vous pouvez fournir des images réactives et plus de styles. Définissez la taille de l'image, utilisez la classe IMG-FLUID pour rendre l'image adaptable. Réglez la bordure en utilisant la classe IMG-border. Réglez les coins arrondis et utilisez la classe Roundée IMG. Réglez l'ombre, utilisez la classe Shadow. Redimensionner et positionner l'image, en utilisant le style CSS. À l'aide de l'image d'arrière-plan, utilisez la propriété CSS d'image d'arrière-plan.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser