<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        ASP.NET怎么操作DataTable實例應用

        來源:懂視網 責編:小采 時間:2020-11-27 22:42:08
        文檔

        ASP.NET怎么操作DataTable實例應用

        ASP.NET怎么操作DataTable實例應用:有機會在博客園的博問頻道上看到一個問題,《ASP.NET怎么操作DataTable》: 如上圖,左邊的這個表是程序構建出來的,不是數據庫表,怎么通過操作DataTable手段得到右邊的四個表? Insus.NET嘗試做了一下,算是練習DataTable的功力了。效果如下: 根據
        推薦度:
        導讀ASP.NET怎么操作DataTable實例應用:有機會在博客園的博問頻道上看到一個問題,《ASP.NET怎么操作DataTable》: 如上圖,左邊的這個表是程序構建出來的,不是數據庫表,怎么通過操作DataTable手段得到右邊的四個表? Insus.NET嘗試做了一下,算是練習DataTable的功力了。效果如下: 根據

        有機會在博客園的博問頻道上看到一個問題,《ASP.NET怎么操作DataTable》:

        如上圖,左邊的這個表是程序構建出來的,不是數據庫表,怎么通過操作DataTable手段得到右邊的四個表?

        Insus.NET嘗試做了一下,算是練習DataTable的功力了。效果如下:

        根據最初數據,Insus.NET在.aspx內放置了一個Gridview,用來顯示最開始的數據。

        代碼如下:
        View Code


        <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="false">
        <Columns>
        <asp:TemplateField>
        <HeaderTemplate>
        Name
        </HeaderTemplate>
        <ItemTemplate>
        <%# Eval("Name") %>
        </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField>
        <HeaderTemplate>
        Quantity
        </HeaderTemplate>
        <ItemTemplate>
        <%# Eval("Quantity") %>
        </ItemTemplate>
        </asp:TemplateField>
        </Columns>
        </asp:GridView>

        創建一個DataTable,并填充數據:
        代碼如下:
        View Code

        DataTable GetData()
        {
        DataTable table = new DataTable();
        table.Columns.Add("Name", typeof(string));
        table.Columns.Add("Quantity", typeof(int));
        table.Rows.Add("a", 1);
        table.Rows.Add("a", 2);
        table.Rows.Add("b", 2);
        table.Rows.Add("b", 2);
        table.Rows.Add("c", 1);
        table.Rows.Add("c", 2);
        table.Rows.Add("c", 3);
        table.Rows.Add("c", 4);
        return table;
        }

        然后為剛才創建的Gridview綁定這個DataTable:
        代碼如下:
        View Code

        protected void Page_Load(object sender, EventArgs e)
        {
        if (!IsPostBack)
        {
        Data_Binding();
        }
        }

        private void Data_Binding()
        {
        this.GridView1.DataSource = GetData();
        this.GridView1.DataBind();
        }

        為了得到報表1,它有三個字段,名稱(Name),數量(Amount)和行數(Rowcount),Insus.NET還參考源數據,它還有一個數量(Quantity)字段。因此,Insus.NET寫了一個類別Item,為以下導出報表作準備:
        代碼如下:
        Item

        using System;
        using System.Collections.Generic;
        using System.Linq;
        using System.Web;

        /// <summary>
        /// Summary description for Item
        /// </summary>
        namespace Insus.NET
        {
        public class Item
        {
        private string _Name;
        private int _Quantity;
        private int _Amount;
        private int _RowCount;

        public string Name
        {
        get { return _Name; }
        set { _Name = value; }
        }
        public int Quantity
        {
        get { return _Quantity; }
        set { _Quantity = value; }
        }
        public int Amount
        {
        get { return _Amount; }
        set { _Amount = value; }
        }
        public int RowCount
        {
        get { return _RowCount; }
        set { _RowCount = value; }
        }

        public Item()
        {
        //
        // TODO: Add constructor logic here
        //
        }

        public Item(string name, int quantity)
        {
        this._Name = name;
        this._Quantity = quantity;
        }

        public Item(string name, int amount,int rowCount)
        {
        this._Name = name;
        this._Amount = amount;
        this._RowCount = rowCount;
        }
        }
        }

        OK,現在我們寫一個報表,在.aspx放在一個按鈕,以及一個GridView,來顯示報表,注意一個字段的綁定。
        代碼如下:
        View Code

        <asp:Button ID="ButtonReport1" runat="server" Text="報表1" OnClick="ButtonReport1_Click" />
        <asp:GridView ID="GridView2" runat="server" AutoGenerateColumns="false">
        <Columns>
        <asp:TemplateField>
        <HeaderTemplate>
        Name
        </HeaderTemplate>
        <ItemTemplate>
        <%# Eval("Name") %>
        </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField>
        <HeaderTemplate>
        Amount
        </HeaderTemplate>
        <ItemTemplate>
        <%# Eval("Amount") %>
        </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField>
        <HeaderTemplate>
        RowCount
        </HeaderTemplate>
        <ItemTemplate>
        <%# Eval("RowCount") %>
        </ItemTemplate>
        </asp:TemplateField>
        </Columns>
        </asp:GridView>

        在.cs 寫click事件:
        代碼如下:
        View Code


        protected void ButtonReport1_Click(object sender, EventArgs e)
        {
        SortedList<string, Item> _sl = new SortedList<string, Item>();

        DataTable otable = GetData();
        foreach (DataRow dr in otable.Rows)
        {
        if (_sl.ContainsKey(dr["Name"].ToString()))
        {
        _sl[dr["Name"].ToString()].Amount += Convert.ToInt32(dr["Quantity"]);
        _sl[dr["Name"].ToString()].RowCount += 1;
        }
        else
        {
        Item i = new Item(dr["Name"].ToString(), Convert.ToInt32(dr["Quantity"]), 1);
        _sl.Add(dr["Name"].ToString(), i);
        }
        }

        this.GridView2.DataSource = _sl.Values;
        this.GridView2.DataBind();
        }

        第一份報表,大功告成,只要DataTable數源數據有變化,報表也會隨之變化。

        接下來,完成第二個報表,在Insus.NET使用Repeater包含Repeater來實現。因此,前臺Html代碼如下,其中第一個Repeate內放置了一個HiddenField,來存儲名稱(Name)字段,當作子Repeater的參考傳入。
        代碼如下:
        View Code


        <asp:Button ID="ButtonReport2" runat="server" Text="報表2" OnClick="ButtonReport2_Click" />
        <asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="Repeater1_ItemDataBound">
        <ItemTemplate>
        <asp:HiddenField ID="HiddenField1" runat="server" Value='<%# Container.DataItem %>' />
        <asp:Repeater ID="Repeater2" runat="server">
        <HeaderTemplate>
        <table border="1" cellspacing="0" cellpadding="5" style="margin: 10px; border-collapse: collapse;">
        <tr>
        <td>Name</td>
        <td>Quantity</td>
        </tr>
        </HeaderTemplate>
        <ItemTemplate>
        <tr>
        <td><%# Eval("Name") %></td>
        <td><%# Eval("Quantity") %></td>
        </tr>
        </ItemTemplate>
        <FooterTemplate>
        </table>
        </FooterTemplate>
        </asp:Repeater>
        </ItemTemplate>
        </asp:Repeater>

        首先,我們需要從DataTable,獲取名稱(Name)唯一的記錄存儲起來,作為第一個Repeate控件的數據集數據源。
        代碼如下:
        View Code


        protected void ButtonReport2_Click(object sender, EventArgs e)
        {
        this.Repeater1.DataSource = Names();
        this.Repeater1.DataBind();
        }

        List<string> Names()
        {
        List<string> t = new List<string>();
        DataTable otable = GetData();
        foreach (DataRow dr in otable.Rows)
        {
        if (!t.Contains(dr["Name"].ToString()))
        t.Add(dr["Name"].ToString());
        }
        return t;
        }

        我們還要寫第二個Repeater控件的數據源:
        代碼如下:
        View Code


        List<Item> GetDataByName(string name)
        {
        List<Item> o = new List<Item>();
        DataTable otable = GetData();
        foreach (DataRow dr in otable.Rows)
        {
        if (name == dr["Name"].ToString())
        {
        Item i = new Item(dr["Name"].ToString(), Convert.ToInt32(dr["Quantity"]));
        o.Add(i);
        }
        }
        return o;
        }

        為第二個Repeater控件綁定數據源,在綁寫之前,得先找到這個控件,因此,你需要在第一個Repeater控件寫OnItemDataBound="Repeater1_ItemDataBound"事件:
        代碼如下:
        View Code


        protected void Repeater1_ItemDataBound(object sender, RepeaterItemEventArgs e)
        {
        if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
        {
        if (e.Item.FindControl("HiddenField1") != null && e.Item.FindControl("Repeater2") != null)
        {
        var hiddenField = e.Item.FindControl("HiddenField1") as HiddenField;
        var repeater = e.Item.FindControl("Repeater2") as Repeater;
        repeater.DataSource = GetDataByName(hiddenField.Value);
        repeater.DataBind();
        }
        }
        }

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        ASP.NET怎么操作DataTable實例應用

        ASP.NET怎么操作DataTable實例應用:有機會在博客園的博問頻道上看到一個問題,《ASP.NET怎么操作DataTable》: 如上圖,左邊的這個表是程序構建出來的,不是數據庫表,怎么通過操作DataTable手段得到右邊的四個表? Insus.NET嘗試做了一下,算是練習DataTable的功力了。效果如下: 根據
        推薦度:
        標簽: 操作 如何 應用
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲成AV人片在| 国产又大又黑又粗免费视频 | 成人毛片免费在线观看| 亚洲人成网址在线观看| 99国产精品免费视频观看| 免费看韩国黄a片在线观看| 亚洲小视频在线播放| 国产精品成人观看视频免费| 久久亚洲精品无码AV红樱桃| 日韩免费人妻AV无码专区蜜桃| 亚洲电影免费在线观看| 四虎最新永久免费视频| 国产成+人+综合+亚洲专| 免费视频淫片aa毛片| 国产精品亚洲色图| 4hu四虎最新免费地址| 亚洲国产最大av| 国产精品免费_区二区三区观看 | a一级毛片免费高清在线| 三上悠亚亚洲一区高清| 免费视频成人手机在线观看网址| 久久精品亚洲精品国产色婷| 免费影院未满十八勿进网站| 国产精品亚洲综合天堂夜夜| 亚洲人精品午夜射精日韩| 久久久久高潮毛片免费全部播放 | 国产国拍亚洲精品mv在线观看| 国产成人精品无码免费看| 亚洲丰满熟女一区二区v| 国产成人在线观看免费网站 | 亚洲 日韩 色 图网站| 亚洲 国产 图片| 国产精品免费看久久久| 亚洲国产成人久久| 亚洲国产香蕉人人爽成AV片久久 | 亚洲精品成人a在线观看| 成人黄网站片免费视频| 亚洲中文字幕乱码一区| 日日噜噜噜噜夜夜爽亚洲精品| 99久久99久久精品免费看蜜桃| 美女被羞羞网站免费下载|