zoukankan      html  css  js  c++  java
  • datagrid多层表头及datagrid列动态统计功能的实现 【转】

    1.datagrid多层表头功能的实现
         实际上Asp.Net下的DataGrid是一个HtmlTable,只不过在HtmlTable的基础上添加了很多属性、方法,纳入ViewState机制,来生成、控制它;有了这一点认识,事情就很好办了,我们可以在属性生成器中定义列的表头,它实际上只不过是在列之间插入了“</td><td>”的html标记,如此而已。
        我们可以在DataGrid中的ItemCreated事件中处理,代码如下:   
            private void DataGrid1_ItemCreated(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
            
    {
                
    if(e.Item.ItemType==ListItemType.Header)
                
    {
                    TableCellCollection tcl
    =e.Item.Cells;
                    tcl.Clear();
                    tcl.Add(
    new TableHeaderCell());
                    tcl[
    0].RowSpan=2;
                    tcl[
    0].Text="项目";

                    tcl.Add(
    new TableHeaderCell());
                    tcl[
    1].ColumnSpan =4;                
                    tcl[
    1].Text="第一季度个人消费情况表</th></tr><tr><td rowspan =\"2\">姓名</td><td colspan=\"3\" align=\"center\">帐目统计</td></tr><tr><td>项目一</td><td>项目二</td><td>项目三</td>";    
                }

        
            }

        2.datagrid列动态统计功能的实现
        首先需要允许DataGrid的页脚显示,用于显示统计列值;
      具体的实现可以在DataGrid中的ItemCreated事件中处理,代码如下:  (intSum1,intSum2,intSum3是全局变量)     

            private void DataGrid1_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
            
    {
                
    if(e.Item.ItemIndex >= 0)
                
    {
                    
    //取指定列的数据总和
                    intSum1 += int.Parse(e.Item.Cells[1].Text.ToString());
                    intSum2 
    += int.Parse(e.Item.Cells[2].Text.ToString());
                    Label lblQuantity 
    = (Label)e.Item.Cells[3].FindControl("lblQuantity"); 
                    intSum3 
    += int.Parse(lblQuantity.Text.ToString());
                }

                
    else if(e.Item.ItemType == ListItemType.Footer)
                
    {
                    e.Item.Cells[
    0].Text = "<font color='red'>总计:</font>";   
                    e.Item.Cells[
    1].Text = "<font color='red'>"+intSum1.ToString()+"</font>"; 
                    e.Item.Cells[
    2].Text = "<font color='red'>"+intSum2.ToString()+"</font>"; 
                    e.Item.Cells[
    3].Text = "<font color='red'>"+intSum3.ToString()+"</font>"; 
                }

            }

        3.综合实例 
        为了帮助大家理解上面功能的实现,我把一个具体实例的代码贴出来以供大家参考! 
        
        前台代码

    <%@ Page language="c#" Codebehind="InSum.aspx.cs" AutoEventWireup="false" Inherits="FLX.Portal.InSum" %>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
    <HTML>
        
    <HEAD>
            
    <title>InSum</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>
            
    <form id="Form1" method="post" runat="server">
                
    <asp:datagrid id="DataGrid1" runat="server" AutoGenerateColumns="False" Width="100%" BorderColor="#CCCCCC"
                    BorderStyle
    ="None" BorderWidth="1px" BackColor="White" CellPadding="3" AllowPaging="True"
                    Font
    -Size="12px" ShowFooter="True">
                    
    <FooterStyle ForeColor="#000066" BackColor="White"></FooterStyle>
                    
    <SelectedItemStyle Font-Bold="True" ForeColor="White" BackColor="#669999"></SelectedItemStyle>
                    
    <ItemStyle ForeColor="#000066" BorderColor="#D4D0C8"></ItemStyle>
                    
    <HeaderStyle ForeColor="Black" BackColor="#E1EEFE"></HeaderStyle>
                    
    <Columns>
                        
    <asp:BoundColumn DataField="id" HeaderText="id"></asp:BoundColumn>
                        
    <asp:BoundColumn DataField="count1" HeaderText="count1"></asp:BoundColumn>
                        
    <asp:BoundColumn DataField="count2" HeaderText="count2"></asp:BoundColumn>
                        
    <asp:TemplateColumn HeaderText="count3">
                            
    <ItemTemplate>
                                
    <asp:Label id=lblQuantity runat="server" Text='<%# DataBinder.Eval(Container, "DataItem.count3") %>'>
                                
    </asp:Label>
                            
    </ItemTemplate>
                        
    </asp:TemplateColumn>
                    
    </Columns>
                    
    <PagerStyle HorizontalAlign="Left" ForeColor="#000066" BackColor="White" Mode="NumericPages"></PagerStyle>
                
    </asp:datagrid>
            
    </form>
        
    </body>
    </HTML>
        后台代码
    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;

    namespace FLX.Portal
    {
        
    /// <summary>
        
    /// InSum 的摘要说明。
        
    /// </summary>

        public class InSum : PortalPagePersonal
        
    {
            
    public int intSum1=0;
            
    public int intSum2=0;
            
    public int intSum3=0;
            
    protected System.Web.UI.WebControls.DataGrid DataGrid1;
            
    private void Page_Load(object sender, System.EventArgs e)
            
    {
                
    // 在此处放置用户代码以初始化页面
                if(!this.IsPostBack)
                
    {
                    
    this.DataGrid1.DataSource =this.GetDataBind();
                    
    this.DataGrid1 .DataBind();
                }

            }


            
    Web 窗体设计器生成的代码

            
    private void DataGrid1_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
            
    {
                
    if(e.Item.ItemIndex >= 0)
                
    {
                    
    //取指定列的数据总和
                    intSum1 += int.Parse(e.Item.Cells[1].Text.ToString());
                    intSum2 
    += int.Parse(e.Item.Cells[2].Text.ToString());
                    Label lblQuantity 
    = (Label)e.Item.Cells[3].FindControl("lblQuantity"); 
                    intSum3 
    += int.Parse(lblQuantity.Text.ToString());
                }

                
    else if(e.Item.ItemType == ListItemType.Footer)
                
    {
                    e.Item.Cells[
    0].Text = "<font color='red'>总计:</font>";   
                    e.Item.Cells[
    1].Text = "<font color='red'>"+intSum1.ToString()+"</font>"; 
                    e.Item.Cells[
    2].Text = "<font color='red'>"+intSum2.ToString()+"</font>"; 
                    e.Item.Cells[
    3].Text = "<font color='red'>"+intSum3.ToString()+"</font>"; 
                }

            }

            
    private DataTable GetDataBind()
            
    {
                
    string sql="select * from Count";
                DataTable dt
    =new DataTable();
                dt
    =this.DataAccessFacade.ExecuteDataTable(sql);
                
    return dt;
            }


            
    private void DataGrid1_ItemCreated(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
            
    {
                
    if(e.Item.ItemType==ListItemType.Header)
                
    {
                    TableCellCollection tcl
    =e.Item.Cells;
                    tcl.Clear();
                    tcl.Add(
    new TableHeaderCell());
                    tcl[
    0].ColumnSpan =4;                
                    tcl[
    0].Text="第一季度个人消费情况表</th></tr><tr><td rowspan =\"2\">姓名</td><td colspan=\"3\" align=\"center\">帐目统计</td></tr><tr><td>项目一</td><td>项目二</td><td>项目三</td>";            
                }

            }

        }

    }

        效果展示

    原文地址:http://www.cnblogs.com/dreamof/archive/2008/06/12/1218525.html
  • 相关阅读:
    使用MacPorts配置PHP开发环境(PHP54+PHP FPM+NGINX+MYSQL55)
    freebsd make 常用命令(非原创)
    可以通过以下步骤生成一个简单的证书:
    Javascript相关的一些碎裂的记忆
    中兴EBG2100路由器固件
    一些javascript内容
    freebsd 记事之PHP环境搭建
    vue3 中使用 vite 时的报错
    Vite2.0 按需引入Element Plus
    移动端横屏
  • 原文地址:https://www.cnblogs.com/Godblessyou/p/1779642.html
Copyright © 2011-2022 走看看