C#頁碼導(dǎo)航顯示及算法實現(xiàn)代碼
更新時間:2012年12月20日 16:10:02 作者:
C#頁碼導(dǎo)航算法要求:頁數(shù)小于等于1時不顯示;頁數(shù)大于10時,自動縮短,需要的朋友可以了解下
頁碼導(dǎo)航,先看顯示效果:

算法要求:
1、頁數(shù)小于等于1時不顯示;
2、頁數(shù)大于10時,自動縮短。
具體代碼如下:
/// <summary>
/// 獲取分頁導(dǎo)航
/// </summary>
/// <param name="intPageIndex">頁碼</param>
/// <param name="intPageCount">頁數(shù)</param>
/// <param name="strUrl">鏈接</param>
/// <returns>HTML代碼</returns>
private string GePageNavgation(int intPageIndex, int intPageCount, string strUrl)
{
StringBuilder sb = new StringBuilder("<div class=\"div_pagenavgation\">");
if (intPageCount > 1)
{
//頁碼顯示
if (intPageIndex == 1)
{
sb.Append("<span class=\"disabled\"> < 上一頁</span>");
}
else if (intPageIndex > 1)
{
sb.Append("<a href=\"" + strUrl + (intPageIndex - 1).ToString() + "\">< 上一頁</a>");
}
bool Dot1 = false, Dot2 = false;
for (int i = 1; i <= intPageCount; i++)
{
if (i == intPageIndex)
{
sb.Append("<span class=\"current\">" + intPageIndex.ToString() + "</span>");
continue;
}
if (i <= 3)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (intPageIndex > 7)
{
if (!Dot1)
{
sb.Append("<span class=\"dotted\">...</span>");
Dot1 = true;
}
}
if (i == intPageIndex - 3)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (i == intPageIndex - 2)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (i == intPageIndex - 1)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (i == intPageIndex + 1)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (i == intPageIndex + 2)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (i == intPageIndex + 3)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if ((intPageCount - intPageIndex) > 6 && i > intPageIndex + 3)
{
if (!Dot2)
{
sb.Append("<span class=\"dotted\">...</span>");
Dot2 = true;
}
}
if (i > intPageCount - 3)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
}
if (intPageIndex == intPageCount)
{
sb.Append("<span class=\"disabled\">下一頁 ></span>");
}
else if (intPageIndex + 1 <= intPageCount)
{
sb.Append("<a href=\"" + strUrl + (intPageIndex + 1).ToString() + "\">下一頁 ></a>");
}
}
sb.Append("</div>");
return sb.ToString();
}
CSS樣式:
.div_pagenavgation{
margin-top:5px;
line-height:20px;
float:right;
}
.div_pagenavgation a{
float:left;
text-decoration:none;
color:#06F;
margin-left:5px;
padding-left:5px;
padding-right:5px;
height:20px;
text-align:center;
display:block;
border:1px #CCC solid;
}
.div_pagenavgation .dotted{
float:left;
}
.div_pagenavgation .current{
float:left;
margin-left:5px;
padding-left:5px;
padding-right:5px;
height:20px;
text-align:center;
display:block;
border:1px #CCC solid ;
background-color:#0080C0;
color:#FFF;
}
.div_pagenavgation .disabled{
float:left;
margin-left:5px;
padding-left:5px;
padding-right:5px;
height:20px;
text-align:center;
display:block;
border:1px #CCC solid;
color:#CCC;
}
產(chǎn)生的HTML如下:
<div class="div_pagenavgation">
<a href="?m=log&page=11">< 上一頁</a>
<a href="?m=log&page=1">1</a>
<a href="?m=log&page=2">2</a>
<a href="?m=log&page=3">3</a>
<span class="dotted">...</span>
<a href="?m=log&page=9">9</a>
<a href="?m=log&page=10">10</a>
<a href="?m=log&page=11">11</a>
<span class="current">12</span>
<a href="?m=log&page=13">13</a>
<a href="?m=log&page=14">14</a>
<a href="?m=log&page=15">15</a>
<span class="dotted">...</span>
<a href="?m=log&page=27">27</a>
<a href="?m=log&page=28">28</a>
<a href="?m=log&page=29">29</a>
<a href="?m=log&page=13">下一頁 ></a>
</div>
說明:很久前趕工完成,基本能夠?qū)崿F(xiàn)要求,沒有經(jīng)過仔細(xì)優(yōu)化,誰優(yōu)化了再回復(fù)看看!

算法要求:
1、頁數(shù)小于等于1時不顯示;
2、頁數(shù)大于10時,自動縮短。
具體代碼如下:
復(fù)制代碼 代碼如下:
/// <summary>
/// 獲取分頁導(dǎo)航
/// </summary>
/// <param name="intPageIndex">頁碼</param>
/// <param name="intPageCount">頁數(shù)</param>
/// <param name="strUrl">鏈接</param>
/// <returns>HTML代碼</returns>
private string GePageNavgation(int intPageIndex, int intPageCount, string strUrl)
{
StringBuilder sb = new StringBuilder("<div class=\"div_pagenavgation\">");
if (intPageCount > 1)
{
//頁碼顯示
if (intPageIndex == 1)
{
sb.Append("<span class=\"disabled\"> < 上一頁</span>");
}
else if (intPageIndex > 1)
{
sb.Append("<a href=\"" + strUrl + (intPageIndex - 1).ToString() + "\">< 上一頁</a>");
}
bool Dot1 = false, Dot2 = false;
for (int i = 1; i <= intPageCount; i++)
{
if (i == intPageIndex)
{
sb.Append("<span class=\"current\">" + intPageIndex.ToString() + "</span>");
continue;
}
if (i <= 3)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (intPageIndex > 7)
{
if (!Dot1)
{
sb.Append("<span class=\"dotted\">...</span>");
Dot1 = true;
}
}
if (i == intPageIndex - 3)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (i == intPageIndex - 2)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (i == intPageIndex - 1)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (i == intPageIndex + 1)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (i == intPageIndex + 2)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if (i == intPageIndex + 3)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
if ((intPageCount - intPageIndex) > 6 && i > intPageIndex + 3)
{
if (!Dot2)
{
sb.Append("<span class=\"dotted\">...</span>");
Dot2 = true;
}
}
if (i > intPageCount - 3)
{
sb.Append("<a href=\"" + strUrl + i.ToString() + "\">" + i.ToString() + "</a>");
continue;
}
}
if (intPageIndex == intPageCount)
{
sb.Append("<span class=\"disabled\">下一頁 ></span>");
}
else if (intPageIndex + 1 <= intPageCount)
{
sb.Append("<a href=\"" + strUrl + (intPageIndex + 1).ToString() + "\">下一頁 ></a>");
}
}
sb.Append("</div>");
return sb.ToString();
}
CSS樣式:
復(fù)制代碼 代碼如下:
.div_pagenavgation{
margin-top:5px;
line-height:20px;
float:right;
}
.div_pagenavgation a{
float:left;
text-decoration:none;
color:#06F;
margin-left:5px;
padding-left:5px;
padding-right:5px;
height:20px;
text-align:center;
display:block;
border:1px #CCC solid;
}
.div_pagenavgation .dotted{
float:left;
}
.div_pagenavgation .current{
float:left;
margin-left:5px;
padding-left:5px;
padding-right:5px;
height:20px;
text-align:center;
display:block;
border:1px #CCC solid ;
background-color:#0080C0;
color:#FFF;
}
.div_pagenavgation .disabled{
float:left;
margin-left:5px;
padding-left:5px;
padding-right:5px;
height:20px;
text-align:center;
display:block;
border:1px #CCC solid;
color:#CCC;
}
產(chǎn)生的HTML如下:
復(fù)制代碼 代碼如下:
<div class="div_pagenavgation">
<a href="?m=log&page=11">< 上一頁</a>
<a href="?m=log&page=1">1</a>
<a href="?m=log&page=2">2</a>
<a href="?m=log&page=3">3</a>
<span class="dotted">...</span>
<a href="?m=log&page=9">9</a>
<a href="?m=log&page=10">10</a>
<a href="?m=log&page=11">11</a>
<span class="current">12</span>
<a href="?m=log&page=13">13</a>
<a href="?m=log&page=14">14</a>
<a href="?m=log&page=15">15</a>
<span class="dotted">...</span>
<a href="?m=log&page=27">27</a>
<a href="?m=log&page=28">28</a>
<a href="?m=log&page=29">29</a>
<a href="?m=log&page=13">下一頁 ></a>
</div>
說明:很久前趕工完成,基本能夠?qū)崿F(xiàn)要求,沒有經(jīng)過仔細(xì)優(yōu)化,誰優(yōu)化了再回復(fù)看看!
相關(guān)文章
Asp.net后臺把腳本樣式輸出到head標(biāo)簽中節(jié)省代碼冗余
最近在學(xué)習(xí)開發(fā)服務(wù)器控件,其它就少不了為控件注冊js和css之類的資源文件,或者直接注冊純腳本樣式。其中就遇到如下問題 1、 注冊的資源文件或純腳本樣式在生成的頁面中都不在head標(biāo)簽中(當(dāng)然這個不影響頁面功能) 2、 一個頁面使用多個一樣的控件時,會出現(xiàn)重復(fù)輸入(出現(xiàn)多余代碼)2013-02-02.NET程序集引用COM組件MSScriptControl遇到問題的解決方法
這篇文章主要為大家詳細(xì)介紹了.NET程序集引用COM組件MSScriptControl遇到問題的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01深入淺析WinForm 進(jìn)程、線程及區(qū)別介紹
進(jìn)程是一個具有獨(dú)立功能的程序關(guān)于某個數(shù)據(jù)集合的一次運(yùn)行活動。線程,有時被稱為輕量級進(jìn)程(Lightweight Process,LWP),是程序執(zhí)行流的最小單元。這篇文章主要介紹了WinForm 進(jìn)程、線程的相關(guān)資料,需要的朋友可以參考下2016-09-09