<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 495,comments - 227,trackbacks - 0
    Asp.net提供了三個功能強大的列表控件:DataGrid、DataList和Repeater控件,但其中只有DataGrid控件提供分頁功能。相對DataGrid,DataList和Repeater控件具有更高的樣式自定義性,所以很多時候我們喜歡使用DataList或Repeater控件來顯示數(shù)據(jù)。


    ?實現(xiàn)DataList或Repeater控件的分頁顯示有幾種方法:
    ?1、寫一個方法或存儲過程,根據(jù)傳入的頁數(shù)返回需要顯示的數(shù)據(jù)表(DataTable)
    ?2、使用PagedDataSource類

    ?????本篇文章主要說怎么使用PagedDataSource類實現(xiàn)DataList和Repeater控件的分頁顯示。DataGrid控件內(nèi)部也使用了PagedDataSource類,PagedDataSource?類封裝?DataGrid?控件的屬性,這些屬性使?DataGrid?可以執(zhí)行分頁。

    ?PagedDataSource?類的部分公共屬性:
    ?AllowCustomPaging??獲取或設(shè)置指示是否啟用自定義分頁的值。?
    ?AllowPaging???獲取或設(shè)置指示是否啟用分頁的值。?
    ?Count????獲取要從數(shù)據(jù)源使用的項數(shù)。?
    ?CurrentPageIndex???獲取或設(shè)置當前頁的索引。?
    ?DataSource???獲取或設(shè)置數(shù)據(jù)源。?
    ?DataSourceCount???獲取數(shù)據(jù)源中的項數(shù)。?
    ?FirstIndexInPage???獲取頁中的第一個索引。?
    ?IsCustomPagingEnabled??獲取一個值,該值指示是否啟用自定義分頁。?
    ?IsFirstPage???獲取一個值,該值指示當前頁是否是首頁。?
    ?IsLastPage???獲取一個值,該值指示當前頁是否是最后一頁。?
    ?IsPagingEnabled???獲取一個值,該值指示是否啟用分頁。?
    ?IsReadOnly???獲取一個值,該值指示數(shù)據(jù)源是否是只讀的。?
    ?IsSynchronized???獲取一個值,該值指示是否同步對數(shù)據(jù)源的訪問(線程安全)。?
    ?PageCount???獲取顯示數(shù)據(jù)源中的所有項所需要的總頁數(shù)。?
    ?PageSize???獲取或設(shè)置要在單頁上顯示的項數(shù)。?
    ?VirtualCount???獲取或設(shè)置在使用自定義分頁時數(shù)據(jù)源中的實際項數(shù)。?

    ??????這些屬性是否和DataGrid的屬性很相似?沒錯,DataGrid控件就是使用PagedDataSource類來實現(xiàn)數(shù)據(jù)分頁顯示的?。下面舉個使用PagedDataSource類實現(xiàn)DataList和Repeater控件的分頁顯示的例子:
    程序代碼 程序代碼

    public?void?Page_Load(Object?src,EventArgs?e)?
    {
    OleDbConnection?objConn=new?OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0;?Data?Source=c:\test.mdb");
    OleDbDataAdapter?objCommand=new?OleDbDataAdapter("select?*?from?Users",objConn);
    DataSet?ds=new?DataSet();
    objCommand.Fill(ds);

    //對PagedDataSource?對象的相關(guān)屬性賦值
    PagedDataSource?objPds?=?new?PagedDataSource();
    objPds.DataSource?=?ds.Tables[0].DefaultView;
    objPds.AllowPaging?=?true;
    objPds.PageSize?=?5;
    int?CurPage;

    //當前頁面從Page查詢參數(shù)獲取
    if?(Request.QueryString["Page"]?!=?null)
    ??CurPage=Convert.ToInt32(Request.QueryString["Page"]);
    else
    ??CurPage=1;

    objPds.CurrentPageIndex?=?CurPage-1;?
    lblCurrentPage.Text?=?"Page:?"?+?CurPage.ToString();

    if?(!objPds.IsFirstPage)
    ??lnkPrev.NavigateUrl=Request.CurrentExecutionFilePath?+?"?Page="?+?Convert.ToString(CurPage-1);

    if?(!objPds.IsLastPage)
    ??lnkNext.NavigateUrl=Request.CurrentExecutionFilePath+?"?Page="?+?Convert.ToString(CurPage+1);

    //把PagedDataSource?對象賦給Repeater控件
    Repeater1.DataSource=objPds;
    Repeater1.DataBind();
    }

    這樣就可以很簡單的實現(xiàn)DataList和Repeater控件的分頁顯示。但這樣做有個缺點,就是每次都要把所有頁的數(shù)據(jù)Select出來,DataGrid也是這樣,這樣會降低一點效率(大多時候體會不出來差別);如果使用第一種方法就可以只Select出當前頁的數(shù)據(jù)(實現(xiàn)方法請查看有關(guān)文章)
    posted on 2007-01-25 13:10 SIMONE 閱讀(1230) 評論(0)  編輯  收藏 所屬分類: .NET
    主站蜘蛛池模板: 日韩欧美一区二区三区免费观看| 免费在线观影网站| 国产成人精品免费视频大全麻豆| 国产av天堂亚洲国产av天堂| 国内精品99亚洲免费高清| 国产国拍精品亚洲AV片| 久久久免费观成人影院| 久久精品国产精品亚洲| 中文字幕免费在线看| 亚洲ⅴ国产v天堂a无码二区| 亚在线观看免费视频入口| 1区1区3区4区产品亚洲| 57pao一国产成视频永久免费| 91精品国产亚洲爽啪在线影院| 3d动漫精品啪啪一区二区免费| 亚洲国产精品成人精品软件 | 三年片免费高清版| 亚洲av中文无码乱人伦在线r▽| 日本免费一区二区三区| 亚洲fuli在线观看| 国产成人免费一区二区三区| 一个人看的www视频免费在线观看 一个人看的免费观看日本视频www | 好大好硬好爽免费视频| 成人嫩草影院免费观看| 亚洲成年轻人电影网站www| 美丽的姑娘免费观看在线播放 | 男女啪啪免费体验区| 亚洲毛片αv无线播放一区| 91精品国产免费| 亚洲精品无码av片| 亚洲色成人网站WWW永久| 免费观看无遮挡www的视频| 亚洲精品国产高清在线观看| 国产成人麻豆亚洲综合无码精品| 免费A级毛片无码专区| 久久水蜜桃亚洲AV无码精品| 久久九九亚洲精品| 妞干网在线免费视频| a级毛片免费全部播放| 亚洲中文无码mv| 国产亚洲精品资源在线26u|