这个控件是在可分页的Repeater中分离出来的,所以具体的使用是一样的。

下面看具体的例子:

HTML如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form runat="server" id="aspnetform">
<asp:Repeater ID="Repeater1" runat="server" EnableViewState="false">
<HeaderTemplate>
<table style="border-collapse: collapse" border="1" cellspacing="0" bordercolor="#000000"
cellpadding="0" width="100%">
<thead>
<tr>
<th>
产品ID
</th>
<th>
产品名称
</th>
<th>
UnitPrice
</th>
<th>
SupplierID
</th>
<th>
ReorderLevel
</th>
</tr>
</thead>
<tbody>
</HeaderTemplate>
<ItemTemplate>
<tr>
<td>
<%
   1: # Eval("ProductID")
%>
</td>
<td>
<%
   1: # Eval("ProductName")
%>
</td>
<td>
<%
   1: # Eval("UnitPrice")
%>
</td>
<td>
<%
   1: # Eval("SupplierID")
%>
</td>
<td>
<%
   1: # Eval("ReorderLevel")
%>
</td>
</tr>
</ItemTemplate>
<FooterTemplate>
</tbody></table>
</FooterTemplate>
</asp:Repeater>
<hxj:AspNetPager ID="AspNetPager1" runat="server">
</hxj:AspNetPager>
</form>
</body>
</html>

设计时:

image

CS代码如下:

protected void Page_Load(object sender, EventArgs e)
{
    
}

protected void Page_PreRender(object sender, EventArgs e)
{
    AspNetPager1.RecordCount = DbSession.Default.Count<Products>(null);
    Repeater1.DataSource = DbSession.Default.From<Products>().Page(AspNetPager1.PageSize, AspNetPager1.CurrentPageIndex).ToList();
    Repeater1.DataBind();
}

这样的话可以不需要写PageChanged或者PageChanging事件啦,而且这样写Url分页也是适用的。

 

运行出来的效果如下:

image

生成的HTML代码:



<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><title>

</title><link href='/WebResource.axd?d=vyU7gXWTEjSzLLEcs_n47WXVuPaV-E2N-8HjlftGlngLF-jVPmRX51BJk2S8tHG-0&t=634088408717344000' rel='stylesheet' type='text/css' /></head>
<body>
<form name="aspnetform" method="post" action="aspnetpager_Test.aspx" id="aspnetform">
<div>
<input type="hidden" name="__VIEWSTATE" id="__VIEWSTATE" value="/wEPDwUJNDkxNTgxMTM2D2QWAgIDD2QWAgIDDxYEHiNfUmVjb3JkY291bnQuSHhqLldlYi5VSS5Bc3BOZXRQYWdlcgJQHihfQ3VycmVudFBhZ2VJbmRleC5IeGouV2ViLlVJLkFzcE5ldFBhZ2VyAgRkZFLetH5uLHGy2fRz9YG343SP5Gno" />
</div>


<script src="/WebResource.axd?d=vyU7gXWTEjSzLLEcs_n47bhRfwHjMQqZ27D_aDTz4r9wiml-MShtKnqLMxSSJExP0&amp;t=634088408717344000" type="text/javascript"></script>
   1:  
   2: <div>
   3:  
   4:     <input type="hidden" name="__EVENTTARGET" id="__EVENTTARGET" value="" />
   5:     <input type="hidden" name="__EVENTARGUMENT" id="__EVENTARGUMENT" value="" />
   6: </div>
   7:     
   8:             <table style="border-collapse: collapse" border="1" cellspacing="0" bordercolor="#000000"
   9:                 cellpadding="0" width="100%">
  10:                 <thead>
  11:                     <tr>
  12:                         <th>
  13:                             产品ID
  14:                         </th>
  15:                         <th>
  16:                             产品名称
  17:                         </th>
  18:                         <th>
  19:                             UnitPrice
  20:                         </th>
  21:                         <th>
  22:                             SupplierID
  23:                         </th>
  24:                         <th>
  25:                             ReorderLevel
  26:                         </th>
  27:                     </tr>
  28:                 </thead>
  29:                 <tbody>
  30:         
  31:             <tr>
  32:                 <td>
  33:                     31
  34:                 </td>
  35:                 <td>
  36:                     Gorgonzola Telino
  37:                 </td>
  38:                 <td>
  39:                     12.5000
  40:                 </td>
  41:                 <td>
  42:                     14
  43:                 </td>
  44:                 <td>
  45:                     20
  46:                 </td>
  47:             </tr>
  48:         
  49:             <tr>
  50:                 <td>
  51:                     32
  52:                 </td>
  53:                 <td>
  54:                     Mascarpone Fabioli
  55:                 </td>
  56:                 <td>
  57:                     32.0000
  58:                 </td>
  59:                 <td>
  60:                     14
  61:                 </td>
  62:                 <td>
  63:                     25
  64:                 </td>
  65:             </tr>
  66:         
  67:             <tr>
  68:                 <td>
  69:                     33
  70:                 </td>
  71:                 <td>
  72:                     Geitost
  73:                 </td>
  74:                 <td>
  75:                     2.5000
  76:                 </td>
  77:                 <td>
  78:                     15
  79:                 </td>
  80:                 <td>
  81:                     20
  82:                 </td>
  83:             </tr>
  84:         
  85:             <tr>
  86:                 <td>
  87:                     34
  88:                 </td>
  89:                 <td>
  90:                     Sasquatch Ale
  91:                 </td>
  92:                 <td>
  93:                     14.0000
  94:                 </td>
  95:                 <td>
  96:                     16
  97:                 </td>
  98:                 <td>
  99:                     15
 100:                 </td>
 101:             </tr>
 102:         
 103:             <tr>
 104:                 <td>
 105:                     35
 106:                 </td>
 107:                 <td>
 108:                     Steeleye Stout
 109:                 </td>
 110:                 <td>
 111:                     18.0000
 112:                 </td>
 113:                 <td>
 114:                     16
 115:                 </td>
 116:                 <td>
 117:                     15
 118:                 </td>
 119:             </tr>
 120:         
 121:             <tr>
 122:                 <td>
 123:                     36
 124:                 </td>
 125:                 <td>
 126:                     Inlagd Sill
 127:                 </td>
 128:                 <td>
 129:                     19.0000
 130:                 </td>
 131:                 <td>
 132:                     17
 133:                 </td>
 134:                 <td>
 135:                     20
 136:                 </td>
 137:             </tr>
 138:         
 139:             <tr>
 140:                 <td>
 141:                     37
 142:                 </td>
 143:                 <td>
 144:                     Gravad lax
 145:                 </td>
 146:                 <td>
 147:                     26.0000
 148:                 </td>
 149:                 <td>
 150:                     17
 151:                 </td>
 152:                 <td>
 153:                     25
 154:                 </td>
 155:             </tr>
 156:         
 157:             <tr>
 158:                 <td>
 159:                     38
 160:                 </td>
 161:                 <td>
 162:                     Côte de Blaye
 163:                 </td>
 164:                 <td>
 165:                     263.5000
 166:                 </td>
 167:                 <td>
 168:                     18
 169:                 </td>
 170:                 <td>
 171:                     15
 172:                 </td>
 173:             </tr>
 174:         
 175:             <tr>
 176:                 <td>
 177:                     39
 178:                 </td>
 179:                 <td>
 180:                     Chartreuse verte
 181:                 </td>
 182:                 <td>
 183:                     18.0000
 184:                 </td>
 185:                 <td>
 186:                     18
 187:                 </td>
 188:                 <td>
 189:                     5
 190:                 </td>
 191:             </tr>
 192:         
 193:             <tr>
 194:                 <td>
 195:                     40
 196:                 </td>
 197:                 <td>
 198:                     Boston Crab Meat
 199:                 </td>
 200:                 <td>
 201:                     18.4000
 202:                 </td>
 203:                 <td>
 204:                     19
 205:                 </td>
 206:                 <td>
 207:                     30
 208:                 </td>
 209:             </tr>
 210:         
 211:             </tbody></table>
 212:         
 213:     
 214:     <div class="pagedefault" id="AspNetPager1div" style="text-align:right;">
 215:     第4/8页,每页10条,共80条  &nbsp;&nbsp;&nbsp;&nbsp;<a href="javascript:__doPostBack('AspNetPager1','1')"><<</a><a href="javascript:__doPostBack('AspNetPager1','3')"><</a><a href="javascript:__doPostBack('AspNetPager1','1')">1</a><a href="javascript:__doPostBack('AspNetPager1','2')">2</a><a href="javascript:__doPostBack('AspNetPager1','3')">3</a><span style="font-weight:Bold;color:red;">4</span><a href="javascript:__doPostBack('AspNetPager1','5')">5</a><a href="javascript:__doPostBack('AspNetPager1','6')">6</a><a href="javascript:__doPostBack('AspNetPager1','7')">7</a><a href="javascript:__doPostBack('AspNetPager1','8')">8</a><a href="javascript:__doPostBack('AspNetPager1','5')">></a><a href="javascript:__doPostBack('AspNetPager1','8')">>></a>
 216: </div>
 217:     
 218: <script type="text/javascript">
 219: //<![CDATA[
 220: var theForm = document.forms['aspnetform'];
 221: if (!theForm) {
 222:     theForm = document.aspnetform;
 223: }
 224: function __doPostBack(eventTarget, eventArgument) {
 225:     if (!theForm.onsubmit || (theForm.onsubmit() != false)) {
 226:         theForm.__EVENTTARGET.value = eventTarget;
 227:         theForm.__EVENTARGUMENT.value = eventArgument;
 228:         theForm.submit();
 229:     }
 230: }
 231: //]]>
</script>

</form>
</body>
</html>

 

 

 

其他的功能,例如快速转页,css样式等使用参考(可分页Repeater的使用)

 

下载

posted on 2010-05-07 15:17  steven hu  阅读(4618)  评论(8编辑  收藏  举报