Ext.NET 4.1.0 GridPanel數據分頁

来源:http://www.cnblogs.com/zhangtingzu/archive/2016/09/01/5830879.html
-Advertisement-
Play Games

針對大量數據在前端展示,需要進行分頁顯示,這裡我使用的數據量為100萬,數據存儲在MongoDb中(也可以存儲在本地文件或其它資料庫中)。最終顯示效果如下: 步驟如下: 1.新建程式並配置,詳見http://www.cnblogs.com/zhangtingzu/p/5746722.html,裡面有 ...


針對大量數據在前端展示,需要進行分頁顯示,這裡我使用的數據量為100萬,數據存儲在MongoDb中(也可以存儲在本地文件或其它資料庫中)。
最終顯示效果如下:

步驟如下:

1.新建程式並配置,詳見http://www.cnblogs.com/zhangtingzu/p/5746722.html,裡面有具體的步驟;

 

2.新建數據類Model:學生類實體

 1    public class StudentInfo
 2     {
 3         public ObjectId _id { get; set; }
 4         public string NumberId { get; set; }
 5         public string Name { get; set; }
 6         public int Age { get; set; }
 7 
 8         [BsonDateTimeOptions(Kind = DateTimeKind.Local)]
 9         public DateTime StartDate { get; set; }
10     }

 

3.前臺頁面(PageIndex.aspx)

 1 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="PageIndex.aspx.cs" Inherits="ExtNetPage.PageIndex" %>
 2 
 3 <!DOCTYPE html>
 4 
 5 <html>
 6 <head runat="server">
 7     <title>Ext.NET4.1.0分頁簡單示例</title>
 8     <link href="/resources/css/examples.css" rel="stylesheet" />
 9 
10     <script type="text/javascript">
11         var AgeChange = function (value) {
12             var template = '<span style="color:{0};font-weight:bolder;font-size:14px;">{1}</span>';
13             if (value >20) {
14                 return Ext.String.format(template, "Red", value);
15             }
16             else {
17                 return Ext.String.format(template, "Blue", value);
18             }
19         }
20     </script>
21 </head>
22 <body>
23     <form runat="server">
24         <ext:ResourceManager runat="server" Theme="Gray" />
25         <ext:GridPanel ID="GridPanel1" runat="server" Title="數組列表" Width="700">
26             <Store>
27                 <ext:Store ID="Store1" runat="server" OnReadData="MyData_Refresh" PageSize="10">
28                     <Proxy>
29                         <ext:PageProxy></ext:PageProxy>
30                     </Proxy>
31                     <Model>
32                         <ext:Model runat="server" IDProperty="NumberId">
33                             <Fields>
34                                 <ext:ModelField Name="NumberId" />
35                                 <ext:ModelField Name="Name" />
36                                 <ext:ModelField Name="Age" />
37                                 <ext:ModelField Name="StartDate" />
38                             </Fields>
39                         </ext:Model>
40                     </Model>
41                 </ext:Store>
42             </Store>
43             <ColumnModel runat="server">
44                 <Columns>
45                     <ext:RowNumbererColumn runat="server" Header="<center>序號</center>" Width="55" Align="Center" />
46                     <ext:Column runat="server" Header="" DataIndex="NumberId" Width="80" Hidden="true" Align="Center" />
47                     <ext:Column runat="server" Header="學號" DataIndex="NumberId" Width="150" Align="Center" />
48                     <ext:Column runat="server" Header="姓名" DataIndex="Name" Width="120" Align="Center" />
49                     <ext:Column runat="server" Header="年齡" DataIndex="Age" Width="80" Align="Center">
50                         <Renderer Fn="AgeChange" />
51                     </ext:Column>
52                     <ext:DateColumn runat="server" Header="入學日期" DataIndex="StartDate" Width="220" Format="yyyy-MM-dd HH:mm:ss" Align="Center" />
53                 </Columns>
54             </ColumnModel>
55             <SelectionModel>
56                 <ext:RowSelectionModel runat="server" Mode="Multi" />
57             </SelectionModel>
58             <View>
59                 <ext:GridView runat="server" StripeRows="true" />
60             </View>
61             <BottomBar>
62                 <ext:PagingToolbar ID="PagingToolbar1" runat="server">
63                     <Items>
64                         <ext:Label runat="server" Text="Page size:" />
65                         <ext:ToolbarSpacer runat="server" Width="10" />
66                         <ext:ComboBox runat="server" ID="cbPageSize" Width="80">
67                             <Items>
68                                 <ext:ListItem Text="1" />
69                                 <ext:ListItem Text="2" />
70                                 <ext:ListItem Text="10" />
71                                 <ext:ListItem Text="20" />
72                             </Items>
73                             <SelectedItems>
74                                 <ext:ListItem Value="10" />
75                             </SelectedItems>
76                             <Listeners>
77                                 <Select Handler="#{GridPanel1}.store.pageSize = parseInt(this.getValue(), 10); #{GridPanel1}.store.reload();" />
78                             </Listeners>
79                         </ext:ComboBox>
80                     </Items>
81                     <Plugins>
82                         <ext:ProgressBarPager runat="server" />
83                     </Plugins>
84                 </ext:PagingToolbar>
85             </BottomBar>
86             <TopBar>
87                 <ext:Toolbar runat="server">
88                     <Items>
89                         <ext:Button runat="server" Text="列印" Icon="Printer" Handler="this.up('grid').print();" />
90                         <ext:Button runat="server" Text="列印當前頁" Icon="Printer" Handler="this.up('grid').print({currentPageOnly : true});" />
91                     </Items>
92                 </ext:Toolbar>
93             </TopBar>
94         </ext:GridPanel>
95     </form>
96 </body>
97 </html>
註:Theme="Gray",可以設置皮膚,Default和Gray比較美觀。

4.後臺數據(PageIndex.aspx.cs)

 1 using Ext.Net;
 2 using ExtNetPage.Model;
 3 using ExtNetPage.Mongo;
 4 using System;
 5 using System.Collections.Generic;
 6 using System.Linq;
 7 using System.Web;
 8 using System.Web.UI;
 9 using System.Web.UI.WebControls;
10 
11 namespace ExtNetPage
12 {
13     public partial class PageIndex : System.Web.UI.Page
14     {
15         protected void Page_Load(object sender, EventArgs e)
16         {
17         }
18         protected void MyData_Refresh(object sender, StoreReadDataEventArgs e)
19         {
20             List<StudentInfo> data = null;
21             int total = 0;
22             data = ExtNetPage.PageIndex.GetPaging(e.Start <= 0 ? 0 : e.Start, Convert.ToInt32(this.cbPageSize.SelectedItem.Value), ref total);
23             e.Total = total;
24             this.Store1.DataSource = data;
25             this.Store1.DataBind();
26         }
27 
28         public static List<StudentInfo> GetPaging(int startRec, int MaxRec, ref int total)
29         {
30             OperatorMongo idb = new OperatorMongo();
31             List<StudentInfo> data = new List<StudentInfo>();
32             data = idb.GetList(startRec, MaxRec, ref total);
33             return data;
34         }
35     }
36 }

 

參考資料:http://examples.ext.net/#/GridPanel/ArrayGrid/ArrayWithPaging

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 系統代碼是平臺內置的、通用的、統一的數據描述。代碼管理(數據字典)是整個平臺中數據描述的有效機制。通過界面進行可視化的操作和維護,能快速錄入和修改平臺上統一的字典數據。有效提高了數據的重覆利用率和產品、項目的開發效率。整個數據字典數據為框架平臺所共用,用戶可以更好地對系統進行自定義管理,以滿足自己的... ...
  • 一、項目背景: 最近,做項目,因為是金融項目,客戶登錄交易的時候,有一個提示框,就是告知客戶要“入市需謹慎”等等,想必大家都遇到這樣的場景,當然,這種提示是沒人會看的,不過作為交易所,這樣的提示又必不可少的。 其實只有一個要求: 必須客戶讀完“確定”按鈕和CheckBox才會生效 客戶只要把滾動條拉 ...
  • 刪除引用中的該dll,重新引用選擇解決方案下的項目引用,下次F12就不會進入到元數據而是進入到源代碼中方便調試 ...
  • 近來一直翻閱國內網站,發現擴展欄位的時候僅僅做到了可以註冊時候添加,並修改資料庫,但是後續的操作就沒有了,那麼列如我添加了昵稱欄位,怎麼顯示呢?不知是不是因為我剛入門的原因,一直沒有找不到方法,最後再國外論壇找到了方法。核心為下麵4句話,簡單記錄,晚上後續展開修改 指路地址 https://blog ...
  • 1. 利用“命名實參”,您將能夠為特定形參指定實參,方法是將實參與該形參的名稱關聯,而不是與形參在形參列表中的位置關聯。 static void Main(string[] args) { Console.WriteLine(CalculateBMI(weight: 123, height: 64) ...
  • 上一篇博文中我們快速的介紹了dapper的一些基本CURD操作,也是我們manipulate db不可或缺的最小單元,這一篇我們介紹下相對複雜 一點的操作,源碼分析暫時就不在這裡介紹了。 一:table sql 為了方便,這裡我們生成兩個表,一個Users,一個Product,sql如下: <1> ...
  • 一、單一職責原則: 全稱:“Single-Responsibility Principle” 面向對象設計 說明:就一個類而言,應該只專註於做一件事和僅有一個引起它變化的原因。所謂職責,我們可以理解他為功能,就是設計的這個類功能應該只有一個,而不是兩個或更多。也可以理解為引用變化的原因,當你發現有兩 ...
  • 覺得很多基礎學習者對VS不太熟悉,我就轉一篇覺得還不錯的。轉自:http://jingyan.baidu.com/article/f3ad7d0fe7ca0d09c3345b84.html 現在大多數同學用的電腦都是Windows 8和8.1,使用VC6.0存在相容性問題,對於初學者來說是一件很麻煩 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...