一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

如何在DataGrid控件中實現自定義分頁

如何在DataGrid控件中實現自定義分頁 
    在一般情況下,DataGrid控件每次實現翻頁操作時,都會將數據源中的數據重新調用一次,當數據中
數據很多時,這樣做就會很浪費系統資源和降低程序的執行效率.這時候我們一般通過自定義分頁來解
決這個問題.
    DataGrid控件的AllowCustomPaging屬性用來獲取或設置DataGrid控件是否允許自定義分
頁;VirtualItemCoun屬性用來獲取或設置在使用自定義分頁時DataGrid中實際的項數.要實現自定義分
頁,必須將AllowPaging與AllowCustomPaging屬性都設置為"True".
    在DataGrid中要實現自定義分頁的關鍵是,使該控件僅僅調用當前顯示所需要的數據源數據,在下
面的例子中通過CurrentPageIndex和PageSize屬性的值,在數據綁定時只取當前頁需要的數據.
    (1)頁面代碼:
復制代碼 代碼如下:
<%@ Page language="c#" Codebehind="Main.ASPx.cs" AutoEventWireup="false" 
Inherits="SissonDemo.Main" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<HTML>
    <HEAD>
        <title>Main</title>
        <meta name="GENERATOR" Content="Microsoft Visual Studio .NET 7.1">
        <meta name="CODE_LANGUAGE" Content="C#">
        <meta name="vs_defaultClientScript" content="JavaScript">
        <meta name="vs_targetSchema" 
content="http://schemas.microsoft.com/intellisense/ie5">
    </HEAD>
    <body MS_POSITIONING="GridLayout">
        <form id="Form1" method="post" runat="server">
            <FONT face="宋體">
                <ASP:DataGrid id="DataGrid1" style="Z-INDEX: 101; LEFT: 8px; POSITION: 
absolute; TOP: 24px" runat="server"
                    Width="792px" Height="96px" AllowCustomPaging="True" 
AllowPaging="True" PageSize="5">
                    <PagerStyle Mode="NumericPages"></PagerStyle>
                </ASP:DataGrid></FONT>
        </form>
    </body>
</HTML>
    (2)后臺代碼:
復制代碼 代碼如下:
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;

namespace SissonDemo
{
    /**//// <summary>
    /// Main 的摘要說明。
    /// </summary>
    public class Main : System.Web.UI.Page
    {
        protected System.Web.UI.WebControls.DataGrid DataGrid1;
         int startIndex = 0;//用來保存當前頁數據項的起始索引
        private void Page_Load(object sender, System.EventArgs e)
        {
            if(!IsPostBack)
            {
                Bind();//初始化時進行數據綁定
            }

        }
        void Bind()//綁定數據方法
        {  //定義數據庫連接對象
            SqlConnection cn=new SqlConnection("server=.;database=pubs;uid=sa;pwd=");
           //創建數據適配對象
            SqlDataAdapter da=new SqlDataAdapter("select title_id ,title ,type, pub_id 
,price,pubdate from titles",cn);
            //創建DataSet對象
            DataSet ds=new DataSet();
            try
            {   //從指定的索引開始取PageSize條記錄.
                da.Fill(ds,startIndex,DataGrid1.PageSize,"CurDataTable");
                da.Fill(ds,"AllDataTable");//填充數據集合
                //設置DataGrid控件實際要顯示的項數
                DataGrid1.VirtualItemCount=ds.Tables["AllDataTable"].Rows.Count;
                //進行數據綁定
                DataGrid1.DataSource=ds.Tables["CurDataTable"];
                DataGrid1.DataBind();

            }
            catch
            {
                Page.RegisterClientScriptBlock("","<script>alert('數據顯示錯
誤');</script>");
            }

        }

        Web 窗體設計器生成的代碼#region Web 窗體設計器生成的代碼
        override protected void OnInit(EventArgs e)
        {
            //
            // CODEGEN: 該調用是 ASP.NET Web 窗體設計器所必需的。
            //
            InitializeComponent();
            base.OnInit(e);
        }

        /**//// <summary>
        /// 設計器支持所需的方法 - 不要使用代碼編輯器修改
        /// 此方法的內容。
        /// </summary>
        private void InitializeComponent()
        {    
            this.DataGrid1.PageIndexChanged += new 
System.Web.UI.WebControls.DataGridPageChangedEventHandler
(this.DataGrid1_PageIndexChanged);
            this.Load += new System.EventHandler(this.Page_Load);

        }
        #endregion

        private void DataGrid1_PageIndexChanged(object source, 
System.Web.UI.WebControls.DataGridPageChangedEventArgs e)
        {
                //設置DataGrid當前頁的索引值為用戶選擇的頁的索引
                DataGrid1.CurrentPageIndex=e.NewPageIndex;
                //取得當前頁為止總共有多少條記錄,以便在就從該記錄開始讀取
                startIndex=DataGrid1.PageSize*DataGrid1.CurrentPageIndex;
               //取得綁定數據
                Bind();
        }
    }
}

    在這段程序中,首先在數據綁定時,設置DataGrid控件的VirtualItemCoun屬性值為查詢結果集中的
記錄總數,然后取得當前頁要顯示的數據,初始化時當前頁顯示的數據為從取到的數據的零位置開始,到
DataGrid控件的PageSize屬性的設定值為止的數據記錄數.在分頁操作中重新定義了取得數據時
的數據項的開始索引值,然后調用數據綁定方法把取到的新數據和DataGrid控件重新綁定. 

AspNet技術如何在DataGrid控件中實現自定義分頁,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 成人特黄午夜性a一级毛片 成人婷婷 | 国产精品对白刺激 | 色涩播| 狠狠久久久久久亚洲综合网 | 91久操| 色哟哟视频在线观看网站 | 日韩dv| 国产人成午夜免视频网站 | 久久国产区 | 人人干人人看 | 精品国产福利第一区二区三区 | 亚洲黄色激情网 | 久久亚洲精品中文字幕亚瑟 | 国产视频第二页 | 在线播放人成午夜免费视频 | 丁香六月婷婷激情 | 久草五月天 | 成人免费看片视频色多多 | 激情小视频在线播放免费 | 全国最大色成免费网站 | baoyu777.永久免费视频 | 久青草国产手机视频免费观看 | 国产精品久久婷婷六月丁香 | 日韩精品一区二区三区中文字幕 | 色婷婷影院 | 男人女人做刺激视频免费 | 一色屋色费精品视频在线观看 | 久久99国产乱子伦精品免 | 制服丝袜怡红院 | 亚洲国产乱码在线精品 | 大尺度福利视频 | 免费xxxxx在线观看网站 | 午夜777| 韩国一大片a毛片女同 | 久久香蕉综合色一综合色88 | 深夜影院深a入口 | 免费永久国产在线视频 | 国产欧美一区二区三区观看 | 色视频免费 | 米奇狠狠 | 国产高清美女一级a毛片久久 |