這篇文章將為大家詳細(xì)講解有關(guān)C#如何實(shí)現(xiàn)分頁(yè)組件,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)建站堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站制作、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的永吉網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
分頁(yè)無(wú)論是前端和后端,基本都有廣泛應(yīng)用!下面通過(guò)一個(gè)小小案例完成這個(gè)分頁(yè)效果:
參數(shù)含義:
string urlFormat: 要傳給服務(wù)器端的URL地址格式,方便在點(diǎn)超鏈接時(shí)進(jìn)行相應(yīng)的跳轉(zhuǎn)
long totalSize: 總的數(shù)據(jù)條數(shù)。
long pageSize: 每頁(yè)多少條數(shù)據(jù)
long currentPage: 當(dāng)前的頁(yè)數(shù)
后面通過(guò)具體的一個(gè)案例來(lái)用這個(gè)分頁(yè)方法:
一.分頁(yè)方法:
////// 生成頁(yè)碼的html /// /// 超鏈接的格式。list.ashx?pagenum={pageNum}。地址中用{pagenum}做為當(dāng)前頁(yè)碼的占位符 /// 總數(shù)據(jù)條數(shù) /// 每頁(yè)多少條數(shù)據(jù) /// 當(dāng)前頁(yè) ///public static RawString Pager(string urlFormat, long totalSize, long pageSize, long currentPage) { StringBuilder sb = new StringBuilder(); //總頁(yè)數(shù) long totalPageCount = (long)Math.Ceiling((totalSize * 1.0f) / (pageSize * 1.0f)); //當(dāng)前頁(yè)的前幾頁(yè) long firstPage = Math.Max(currentPage - 5, 1); //當(dāng)前頁(yè)的后幾頁(yè) long lastPage = Math.Min(currentPage + 6, totalPageCount); //繪制分頁(yè),首頁(yè) sb.AppendLine(""); return new RawString(sb.ToString()); }
二.案例調(diào)用:
服務(wù)器端(test.ashx):這里為了方便看到效果,展示數(shù)據(jù)直接用的固定數(shù)據(jù)
public void ProcessRequest(HttpContext context) { context.Response.ContentType = "text/html"; long pn = Convert.ToInt64(context.Request["pn"]); if (pn == 0) //Convert.ToInt64(null)返回的是0 { pn = 1; } long[] num = new long[50]; //這里的數(shù)據(jù)用的是固定數(shù)據(jù) for (int i = 0; i < 50; i++) { num[i] = ((pn-1) * 50) + i; } OutputRazor(context, "~/test.cshtml", new { nums=num,page=pn}); //這里用的Razor模板引擎 }
這里的Razor方法見(jiàn):Razor模板引擎簡(jiǎn)單介紹
UI端展示(test.cshtml):
效果圖:
三.jQuery分頁(yè)插件:
前面寫(xiě)的這些主要是進(jìn)行功能的實(shí)現(xiàn),樣式效果差了點(diǎn)。下面貼上通過(guò)jQuery實(shí)現(xiàn)的分頁(yè)效果
jQuery的效果圖,及調(diào)用方法:
完整代碼:
一個(gè)非常簡(jiǎn)單的jQuery分頁(yè)插件 調(diào)用方法: $(".tcdPageCode").createPage({ pageCount:20, current:1, backFn:function(p){ //單擊回調(diào)方法,p是當(dāng)前頁(yè)碼 } }); pageCount:總頁(yè)數(shù) current:當(dāng)前頁(yè)
C#是一個(gè)簡(jiǎn)單、通用、面向?qū)ο蟮木幊陶Z(yǔ)言,它由微軟Microsoft開(kāi)發(fā),繼承了C和C++強(qiáng)大功能,并且去掉了一些它們的復(fù)雜特性,C#綜合了VB簡(jiǎn)單的可視化操作和C++的高運(yùn)行效率,以其強(qiáng)大的操作能力、優(yōu)雅的語(yǔ)法風(fēng)格、創(chuàng)新的語(yǔ)言特性和便捷的面向組件編程從而成為.NET開(kāi)發(fā)的首選語(yǔ)言,但它不適用于編寫(xiě)時(shí)間急迫或性能非常高的代碼,因?yàn)镃#缺乏性能極高的應(yīng)用程序所需要的關(guān)鍵功能。
關(guān)于“C#如何實(shí)現(xiàn)分頁(yè)組件”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。