精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

.NET中使用BootstrapBlazor組件庫Table實操篇

開發(fā) 前端
今天我們主要來講解一下在.NET中使用BootstrapBlazor組件庫的Table表格組件(本章使用的數(shù)據(jù)都是程序自動生成的模擬數(shù)據(jù),不需要與數(shù)據(jù)庫打交道)。

前言

Table表格在后臺管理應用中使用的是相當頻繁的,因此找一個功能齊全的前端框架對于我們而言是非常必要的,因為封裝完善的前端框架能夠大大提升我們的工作對接效率。今天我們主要來講解一下在.NET中使用BootstrapBlazor組件庫的Table表格組件(本章使用的數(shù)據(jù)都是程序自動生成的模擬數(shù)據(jù),不需要與數(shù)據(jù)庫打交道)。

圖片圖片

BootstrapBlazor介紹

圖片圖片

  • 使用文檔:https://www.blazor.zone/introduction
  • Gitee項目地址:https://gitee.com/LongbowEnterprise/BootstrapBlazor

BootstrapBlazor是一套基于 Bootstrap 和 Blazor 的企業(yè)級組件庫,可以認為是 Bootstrap 項目的 Blazor 版實現(xiàn)。基于 Bootstrap 樣式庫精心打造,并且額外增加了 100 多種常用的組件,為您快速開發(fā)項目帶來非一般的感覺(喜歡Bootstrap風格的同學推薦使用)。

.NET BootstrapBlazor UI組件庫引入

BootstrapBlazor Table使用前提條件!

https://mp.weixin.qq.com/s/UIeKSqym8ibLRvDwra8aww

首先定義StudentViewModel

public class StudentViewModel
    {
        /// <summary>
        /// StudentID
        /// </summary>
        public int StudentID { get; set; }

        /// <summary>
        /// 班級名稱
        /// </summary>
        public string ClassName { get; set; }

        /// <summary>
        /// 學生姓名
        /// </summary>
        public string Name { get; set; }

        /// <summary>
        /// 學生年齡
        /// </summary>
        public int Age { get; set; }

        /// <summary>
        /// 學生性別
        /// </summary>
        public string Gender { get; set; }
    }

.NET后臺模擬數(shù)據(jù)和增刪改查方法封裝

using BootstrapBlazor.Components;
using WebUI.Model;

namespace WebUI.Pages
{
    public partial class StudentExample
    {
        private static readonly Random random = new Random();
        public static List<StudentViewModel>? StudentInfoList;

        public StudentExample()
        {
            StudentInfoList = GenerateUserInfos();
        }

        /// <summary>
        /// 模擬數(shù)據(jù)庫用戶信息生成
        /// </summary>
        /// <returns></returns>
        public static List<StudentViewModel> GenerateUserInfos()
        {
            return new List<StudentViewModel>(Enumerable.Range(1, 200).Select(i => new StudentViewModel()
            {
                StudentID = i,
                ClassName = $"時光 {i} 班",
                Name = GenerateRandomName(),
                Age = random.Next(20, 50),
                Gender = GenerateRandomGender()
            }));
        }

        /// <summary>
        /// 生成隨機性別
        /// </summary>
        /// <returns></returns>
        public static string GenerateRandomGender()
        {
            string[] genders = { "男", "女" };
            return genders[random.Next(genders.Length)];
        }

        /// <summary>
        /// 生成隨機姓名
        /// </summary>
        /// <returns></returns>
        public static string GenerateRandomName()
        {
            string[] surnames = { "張", "王", "李", "趙", "劉" };
            string[] names = { "明", "紅", "強", "麗", "軍" };
            string surname = surnames[random.Next(surnames.Length)];
            string name = names[random.Next(names.Length)];
            return surname + name;
        }

        /// <summary>
        /// 數(shù)據(jù)查詢
        /// </summary>
        /// <param name="options">options</param>
        /// <returns></returns>
        private Task<QueryData<StudentViewModel>> OnQueryAsync(QueryPageOptions options)
        {
            List<StudentViewModel> studentInfoData = StudentInfoList;

            // 數(shù)據(jù)模糊過濾篩選
            if (!string.IsNullOrWhiteSpace(options.SearchText))
            {
                studentInfoData = studentInfoData.Where(x => x.Name.Contains(options.SearchText)).ToList();
            }

            return Task.FromResult(new QueryData<StudentViewModel>()
            {
                Items = studentInfoData.Skip((options.PageIndex - 1) * options.PageItems).Take(options.PageItems).ToList(),
                TotalCount = studentInfoData.Count()
            });
        }

        /// <summary>
        /// 模擬數(shù)據(jù)增加和修改操作
        /// </summary>
        /// <param name="studentInfo">studentInfo</param>
        /// <param name="changedType">changedType</param>
        /// <returns></returns>
        public Task<bool> OnSaveAsync(StudentViewModel studentInfo, ItemChangedType changedType)
        {
            if (changedType.ToString() == "Update")
            {
                var queryInfo = StudentInfoList.FirstOrDefault(x => x.StudentID == studentInfo.StudentID);
                if (queryInfo != null)
                {
                    queryInfo.Age = studentInfo.Age;
                    queryInfo.ClassName = studentInfo.ClassName;
                    queryInfo.Name = studentInfo.Name;
                    queryInfo.Gender = studentInfo.Gender;
                }
            }
            else if (changedType.ToString() == "Add")
            {
                StudentInfoList.Add(studentInfo);
            }
            return Task.FromResult(true);
        }

        /// <summary>
        /// 數(shù)據(jù)刪除
        /// </summary>
        /// <param name="items">items</param>
        /// <returns></returns>
        private Task<bool> OnDeleteAsync(IEnumerable<StudentViewModel> items)
        {
            items.ToList().ForEach(i => StudentInfoList.Remove(i));
            return Task.FromResult(true);
        }
    }
}

一行代碼快速生成Table表格

<Table TItem="StudentViewModel" AutoGenerateColumns="true" Items="StudentInfoList"></Table>

圖片圖片

顯示Table工具欄

<Table TItem="StudentViewModel" AutoGenerateColumns="true" Items="StudentInfoList" ShowToolbar="true"></Table>

圖片圖片

顯示Table多選模式

<Table TItem="StudentViewModel" AutoGenerateColumns="true" Items="StudentInfoList" ShowToolbar="true" IsMultipleSelect="true"></Table>

圖片圖片

增加Table搜索功能

<Table TItem="StudentViewModel" AutoGenerateColumns="true" Items="StudentInfoList" ShowToolbar="true" IsMultipleSelect="true" ShowSearch="true">

    <SearchTemplate>
        <GroupBox Title="搜索條件">
            <div class="row g-3 form-inline">
                <div class="col-12 col-sm-6">
                    <BootstrapInput @bind-Value="@context.Name" PlaceHolder="請輸入姓名" maxlength="50" ShowLabel="true" DisplayText="姓名" />
                </div>
                <div class="col-12 col-sm-6">
                    <BootstrapInput @bind-Value="@context.Gender" PlaceHolder="請輸入性別" maxlength="500" ShowLabel="true" DisplayText="性別" />
                </div>
            </div>
        </GroupBox>
    </SearchTemplate>

</Table>

圖片圖片

增加Table增、刪、改、查、分頁功能

<Table TItem="StudentViewModel"
       AutoGenerateColumns="true"
       ShowToolbar="true"
       IsMultipleSelect="true"
       OnSaveAsync="@OnSaveAsync"
       OnQueryAsync="@OnQueryAsync"
       OnDeleteAsync="@OnDeleteAsync"
       IsStriped="true"
       IsBordered="true"
       ShowSearch="true"
       IsPaginatinotallow="true"
       ShowSearchText="true">

    <TableColumns>
        <TableColumn Sortable="true" Filterable="true" Searchable="true" @bind-Field="@context.StudentID" />
        <TableColumn Sortable="true" Filterable="true" Searchable="true" @bind-Field="@context.Name" />
        <TableColumn Sortable="true" Filterable="true" Searchable="true" @bind-Field="@context.ClassName" />
        <TableColumn Sortable="true" Filterable="true" Searchable="true" @bind-Field="@context.Gender" />
    </TableColumns>

    <SearchTemplate>
        <GroupBox Title="搜索條件">
            <div class="row g-3 form-inline">
                <div class="col-12 col-sm-6">
                    <BootstrapInput @bind-Value="@context.Name" PlaceHolder="請輸入姓名" maxlength="50" ShowLabel="true" DisplayText="姓名" />
                </div>
                <div class="col-12 col-sm-6">
                    <BootstrapInput @bind-Value="@context.Gender" PlaceHolder="請輸入性別" maxlength="500" ShowLabel="true" DisplayText="性別" />
                </div>
            </div>
        </GroupBox>
    </SearchTemplate>
</Table>


責任編輯:武曉燕 來源: 追逐時光者
相關推薦

2010-04-13 16:30:13

Oracle權限

2021-05-12 10:40:09

索引數(shù)據(jù)庫代碼

2010-05-21 17:51:58

MySQL數(shù)據(jù)庫

2010-05-25 11:13:07

MySQL數(shù)據(jù)庫

2023-12-28 08:00:00

數(shù)據(jù)庫人工智能

2009-01-19 09:14:31

.NETMySQLMySql驅(qū)動包

2010-04-09 09:07:43

Oracle游標觸發(fā)器

2010-04-14 10:48:49

Oracle使用

2009-12-23 17:22:18

Linux系統(tǒng)rsyn

2010-05-04 09:14:11

Oracle數(shù)據(jù)庫

2025-08-26 03:00:00

Excel技巧數(shù)據(jù)

2010-04-09 15:22:57

Oracle數(shù)據(jù)庫

2010-05-17 15:58:05

MySQL Admin

2010-05-19 15:01:14

MySQL數(shù)據(jù)導入

2010-10-25 13:17:21

Mono

2010-01-06 10:38:16

Linux安裝JDK

2010-04-12 09:36:29

Oacle merge

2010-05-14 13:32:07

MySQL數(shù)據(jù)庫

2010-06-12 09:46:05

MySQL數(shù)據(jù)庫

2010-05-21 12:15:52

點贊
收藏

51CTO技術棧公眾號

日本亚洲欧美| 久久精品欧美一区二区| 久久亚洲精品人成综合网| 国产精品久久久久永久免费观看| 成人一区二区电影| 国产在线观看免费av| 欧美人与物videos另类xxxxx| 欧美色图天堂网| 亚洲av综合色区| 亚州精品国产精品乱码不99按摩| 奇米亚洲午夜久久精品| 欧美精品18videosex性欧美| 性猛交ⅹxxx富婆video| 日韩中文字幕无砖| 色久综合一二码| www.欧美黄色| 日本a在线播放| 91色视频在线| 99精品国产一区二区| 日韩在线视频不卡| 亚洲承认在线| 久久久国产视频91| 性欧美一区二区| 久久黄色影视| 日韩欧美国产综合在线一区二区三区 | 丰满少妇被猛烈进入高清播放| 美女国产在线| 欧美国产精品一区二区三区| 韩国成人av| 亚洲产国偷v产偷v自拍涩爱| 精品系列免费在线观看| 欧美在线日韩在线| 日本少妇激情视频| 欧美天堂亚洲电影院在线观看 | 鲁大师影院一区二区三区| 色与欲影视天天看综合网| 亚洲天堂精品一区| 少妇精品久久久一区二区三区| 精品免费视频一区二区| 亚洲精品在线网址| 四虎视频在线精品免费网址| 在线观看一区二区视频| 一本大道熟女人妻中文字幕在线| 在线āv视频| 亚洲色图19p| 欧美 日韩 国产 在线观看| 最新国产在线观看| 国产精品久久毛片| 中文网丁香综合网| 欧美一区二区三区| 亚洲欧洲无码一区二区三区| 亚洲在线观看一区| 国产在线视频你懂得| 国产午夜精品一区二区三区四区| 久久99精品久久久久久水蜜桃| 人妻一区二区三区四区| 成人h精品动漫一区二区三区| 国产成人精品自拍| 蜜桃视频久久一区免费观看入口| 国产91精品欧美| 国产精品日韩二区| 天天色综合av| 久久久激情视频| 欧美一区二视频在线免费观看| 蜜桃视频在线观看网站| 国产色一区二区| 婷婷五月色综合| 1024视频在线| 亚洲一线二线三线久久久| 91九色丨porny丨国产jk| 精品人人视频| 91九色最新地址| 小明看看成人免费视频| 精品国产一区二区三区性色av| 日韩欧美美女一区二区三区| 国产精品成人无码专区| 国内黄色精品| 不卡av在线播放| 国产成人无码精品久久久久| 日韩制服丝袜av| 5g国产欧美日韩视频| 五月婷婷丁香网| 欧美激情一二三区| 超碰10000| 在线免费日韩片| 欧美日韩国产片| 无码国产精品一区二区免费式直播 | 国产在线资源一区| 国产精品四虎| 一区二区三区在线观看欧美| 北条麻妃在线视频观看| 欧美一级免费| 亚洲成avwww人| 无码人妻丰满熟妇啪啪欧美| 女生裸体视频一区二区三区 | 欧美激情喷水| 91精品久久久久久久91蜜桃| 水蜜桃av无码| 999久久久精品国产| 97精品一区二区视频在线观看| 无码人妻久久一区二区三区| 国产精品一区二区你懂的| 久久综合给合久久狠狠色| 男人的天堂在线视频免费观看| 亚洲一区在线观看视频| 亚州精品一二三区| 国产精品香蕉| 久久五月情影视| 亚洲s码欧洲m码国产av| 国产成人午夜精品5599 | av免费在线一区二区三区| 一区二区视频在线看| 黄色一级免费大片| 美女一区二区在线观看| 久久最新资源网| 免费黄色一级大片| 91蜜桃在线观看| 日韩一区二区高清视频| 午夜精品久久久久久毛片| 亚洲男人天堂2019| 日韩av片在线播放| 国产精品一区二区黑丝| 亚洲精美视频| 日韩高清成人| 日韩精品在线免费观看| 久久精品国产av一区二区三区| 久久精品72免费观看| 秋霞久久久久久一区二区| 国产福利电影在线播放| 欧美久久久影院| a级黄色免费视频| 日韩av一区二区三区| 蜜桃成人在线| 在线男人天堂| 日韩电影网在线| 日本亚洲欧美在线| 99视频一区二区三区| 青青青在线视频播放| 亚洲码欧美码一区二区三区| 久久夜色精品亚洲噜噜国产mv| 一区二区视频在线免费观看| 国产视频一区不卡| 中文字幕第80页| 欧美日韩精品一区二区视频| 日本精品视频在线| 九色在线观看| 在线影院国内精品| 娇妻被老王脔到高潮失禁视频| 久久久成人网| 日韩午夜视频在线观看| 九色成人搞黄网站| 色999日韩欧美国产| 伊人免费在线观看| 成人免费在线视频| 四川一级毛毛片| 亚洲一级一区| 久久资源亚洲| 成人自拍视频网| 久久网福利资源网站| 性一交一乱一乱一视频| 亚洲成av人综合在线观看| 日b视频在线观看| 久久看片网站| 亚洲资源在线网| 色播一区二区| 久久久久成人网| 日韩av成人| 欧美色图12p| 18精品爽视频在线观看| 成人av网站大全| 日av中文字幕| 图片区亚洲欧美小说区| av观看久久| 久久爱91午夜羞羞| 日韩一二三在线视频播| 亚洲精品久久久久久动漫器材一区| 亚洲国产成人av好男人在线观看| 国产精品无码网站| 轻轻草成人在线| 少妇一晚三次一区二区三区| 日韩av午夜| 国产日产欧美a一级在线| 免费在线观看av电影| 精品丝袜一区二区三区| 国产精品久久影视| 五月综合激情婷婷六月色窝| 手机av在线不卡| 国产不卡在线播放| 午夜视频在线瓜伦| 欧美精品大片| 日韩欧美视频第二区| 日韩在线成人| 国产精品亚洲精品| 成人免费图片免费观看| 最近2019年中文视频免费在线观看| 国产成人久久精品77777综合 | 欧美在线电影| 999国内精品视频在线| 日韩免费电影| 色综合色综合久久综合频道88| 免费在线视频你懂得| 日韩一二在线观看| 自拍偷拍福利视频| 欧美日韩黄色大片| 欧美爱爱小视频| 久久久久久免费网| 亚洲一区二区三区黄色| 经典三级在线一区| 99色精品视频| 精品动漫av| www.黄色网址.com| 欧美先锋资源| 欧美日韩一区在线播放| 超碰精品在线| 91久久国产综合久久91精品网站| 欧美大片免费观看网址| 91国内免费在线视频| av软件在线观看| 色哟哟入口国产精品| 免费理论片在线观看播放老| 日韩精品一区二区三区四区视频 | 久久精品国产免费| 欧美一级片中文字幕| 在线精品福利| 屁屁影院ccyy国产第一页| 五月天综合网站| 亚洲一区二区在线观| 精品不卡一区| 欧洲精品码一区二区三区免费看| 国产精品网在线观看| 国产高清不卡av| 免费精品一区| 亚洲一区二区中文字幕| 一级欧美视频| 国产欧美一区二区三区在线看| 成人软件在线观看| 国产成人在线视频| 综合在线影院| 国产精品第一区| 日韩美女在线看免费观看| 日韩av免费在线| 美女福利一区二区| 国产精品爱啪在线线免费观看| 日韩激情电影免费看| 91成人福利在线| 不卡av影片| 国产精品第1页| 日韩毛片免费视频一级特黄| 国产在线一区二区三区| 亚洲国产一区二区久久| 91美女片黄在线观| 日韩视频一区二区三区四区| av成人综合网| 色婷婷综合久久久久久| 欧美一级二级三级| 欧美日韩有码| 国产高清免费在线| 国内激情久久| 大陆极品少妇内射aaaaa| 美女尤物久久精品| 在线观看av网页| 国产一区二区三区久久悠悠色av| 亚洲热在线视频| 成人av网站大全| 欧洲av一区二区三区| 国产精品欧美一级免费| 黄色片子在线观看| 亚洲国产乱码最新视频| 国产成人免费看| 欧美视频第二页| 国产欧美一级片| 亚洲国模精品一区| 成人高潮成人免费观看| 精品国产一区二区三区久久狼黑人| 国产黄大片在线观看画质优化| 欧美黑人性视频| 台湾佬中文娱乐久久久| 成人激情电影一区二区| 国产另类在线| 亚洲aⅴ天堂av在线电影软件| 国产精品成久久久久| 五十路熟女丰满大屁股| 免费高清在线视频一区·| 日日夜夜精品视频免费观看 | 91麻豆精品国产91久久久久| 亚洲黄色小说网| 亚洲人成电影网站色…| caoporn97在线视频| 国内精品免费午夜毛片| 国产私拍福利精品视频二区| 9a蜜桃久久久久久免费| 激情五月综合| 台湾无码一区二区| 蜜臀久久久久久久| 国产高清成人久久| 国产精品国产精品国产专区不蜜| 精品亚洲永久免费| 欧美日本视频在线| 日韩中文字幕免费观看| zzjj国产精品一区二区| 午夜欧美激情| 999视频在线免费观看| 国产一区二区三区四区| 男女日批视频在线观看| 久久超级碰视频| 欧美做受xxxxxⅹ性视频| 亚洲午夜久久久久中文字幕久| 中文字幕网址在线| 日韩高清不卡av| 污视频网站在线免费| 国产精品一区=区| 亚洲警察之高压线| 成年人网站国产| 激情久久五月天| 亚洲精品国产精品国自产网站| 亚洲国产成人91porn| 国产区精品在线| 色吧影院999| 亚州一区二区三区| 欧美不卡1区2区3区| 亚洲小说欧美另类社区| 在线视频一二区| 国产精品天干天干在观线| 黄色在线视频网址| 亚洲欧美www| 美女高潮在线观看| 国产欧美亚洲日本| 国产精品国码视频| 永久免费看片在线观看| 综合自拍亚洲综合图不卡区| 中国一区二区视频| 中日韩午夜理伦电影免费 | 公肉吊粗大爽色翁浪妇视频| 欧美日韩国产限制| 天天爽夜夜爽夜夜爽| 97免费视频在线| 国产精品sss在线观看av| 久久人妻无码一区二区| 国内精品免费**视频| 三级黄色在线观看| 7777精品伊人久久久大香线蕉 | 国语自产在线不卡| 国产成人tv| 水蜜桃色314在线观看| 波波电影院一区二区三区| 久久精品视频6| 亚洲激情在线观看视频免费| caoporn视频在线观看| 国产视频一区二区不卡| 在线一区欧美| 蜜桃无码一区二区三区| 欧美自拍偷拍午夜视频| 午夜视频在线| 91精品在线国产| 国产主播一区| www.超碰97| 91电影在线观看| 久草免费在线观看| 91传媒免费看| 99综合在线| 天天躁日日躁aaaa视频| 欧美日韩一区二区三区在线| 欧美天天影院| 国产精品yjizz| 亚洲在线观看| 免费黄色国产视频| 日韩欧美精品在线视频| 手机av在线| 色女孩综合网| 国产成人99久久亚洲综合精品| 伊人国产在线观看| 亚洲精选中文字幕| 亚洲欧美在线人成swag| www.在线观看av| 国产午夜精品一区二区三区四区 | 激情图片小说一区| 国产性猛交普通话对白| 亚洲男人av在线| 欧美经典影片视频网站| 成人免费aaa| 亚洲国产岛国毛片在线| www香蕉视频| 青青草国产精品一区二区| 999精品一区| 朝桐光av一区二区三区| 欧美性猛交xxxx黑人交| 亚洲性图自拍| 日韩欧美手机在线| 国产成人综合网| 日韩精品在线一区二区三区| 欧美日韩电影在线观看| 米奇777超碰欧美日韩亚洲| 999热精品视频| 色视频一区二区| 欧美日韩色网| 亚洲精品国产精品国自产| 成人午夜视频在线观看| 一卡二卡三卡在线观看| 91精品国产成人| 午夜精品999|