Samuel Learning

  • 联系
  •  
  • 管理

文章分类(203)

  • 01 ASP/HTML(6)
  • 02 Script/CSS(16)
  • 03 C/C++
  • 04 XML(4)
  • 05 微软编程(26)
  • 06 J2EE(60)
  • 09 Linux(14)
  • 10 Database(27)
  • 11 报表打印
  • 12 打包安装(1)
  • 13 模式重构(2)
  • 14 系统架构
  • 15 敏捷开发(11)
  • 16 案例分析(30)
  • 17 Workflow(1)
  • 18 配置管理(1)
  • 19 项目管理
  • 20 英语(4)

新闻分类(52)

  • CXF学习
  • Hibernate学习(1)
  • iBatis学习(16)
  • Struts1学习(1)
  • Struts2学习(34)

.NET资源

  • adxmenu
  • C# Open Source
  • DNN Directory
  • M2Land
  • Windows Form FAQ
  • 中国DNN
  • 中国DNN联盟

Ajax

  • DoJo
  • GWT
  • JQuery
  • jquery autocomplete
  • jquery flexgrid
  • JQuery Form
  • jquery masked input
  • JQuery UI
  • jquery validation
  • Jquery 图表
  • jquery报表
  • jquery插件集合
  • Qooxdoo
  • Tibco GI
  • YUI
  • YUI-EXT
  • ZeroKode

Java开源

  • ABLE
  • Agile Tao
  • Ajax4JSF
  • Alfresco
  • AppFuse
  • Compiere
  • Equinox
  • Findbugs
  • Geronimo
  • Grails
  • Harmony
  • Hibernate论坛
  • JAG
  • Java开源大全
  • Java视线论坛
  • jBPM工作流
  • JSFTutorials
  • Nereide ERP
  • Ofbiz ERP
  • Opentaps ERP
  • operamasks
  • Petstore
  • Prototype.js
  • RIFE
  • Runa
  • SpringSide
  • Struts Menu
  • Sun Glassfish
  • Trails
  • YUI4JSF
  • 满江红

Mobile

  • Sencha

WEB资源

  • DHTML中心
  • DHTML参考手册
  • DHTML文档
  • EclipsePlugin
  • Firebug
  • GRO Clinux
  • jMaki
  • JSTL文档
  • LoadIcon
  • Openlaszlo
  • Struts Menu 展示
  • Web Test Tools
  • WebCtrs
  • Webdeveloper
  • 中国RIA开发者论坛

Workflow

  • E-Workflow
  • JBPM
  • OpenWFE
  • OSWorkflow
  • WFMC
  • Workflow Research

其他连接

  • confach
  • CPP
  • ejay
  • Giovanni
  • 丹佛
  • 交大e-learning
  • 交大研究生院
  • 可恶的猫
  • 天天@blog
  • 我的相册
  • 阿飞

大牛人

  • 32篇JBPM
  • David.Turing
  • HongSoft@业务集成
  • Joel
  • Koen Aers
  • Martinfowler
  • Raible Matt
  • Raible Wiki
  • Scott W.Ambler
  • Tom Baeyens
  • Uncle Bob
  • 一个世界在等待
  • 子在川上曰
  • 小布老师
  • 小明
  • 差沙
  • 徐昊
  • 江南白衣
  • 汪博士
  • 汪小金
  • 银狐999

开源软件

  • 2Bizbox ERP
  • CompiereCRM&ERP
  • EGW
  • Vtiger CRM
  • webERP

敏捷

  • Canoo
  • Cruisecontrol
  • DBUnit
  • EL4Ant
  • Extreme Programming
  • Fit
  • Fitnesse
  • JFrog
  • Liquibase
  • Maven
  • MockObjects
  • Selenium
  • Squish
  • xpairtise
  • XPlanner
  • XProgramming
  • 敏捷联盟

数据库

  • Oracle 中国
  • Oracle-ERP
  • Oracle在线社区

未归类

  • Aquarius Orm Studio
  • mambo建站系统
  • Oracle产品下载
  • 远程同步管理工具Capivara

经典框架

  • Apache Shale
  • formdef-struts
  • FreeMarker 主页
  • JBoss Seam
  • JSF 中心
  • JSF 入门应用
  • JSF中国
  • MyFaces官方
  • Spring 社区
  • Spring专业网站
  • Spring中文论坛
  • Spring参考手册
  • Spring官方网站
  • strecks-struts
  • Struts1
  • Struts2
  • Struts-layout
  • StrutsWiKi
  • Tapestry WIKI
  • Tapestry 官方
  • Tapestry4开发指南
  • Tapestry中文文档
  • Webwork2文档
  • Wicket

网络教程

  • Laliluna
  • RoseIndia
  • Sang Shin
  • Visualbuilder

著名站点

  • Buildix
  • Dev2Dev
  • IBM dev中国
  • InfoQ
  • ITPub
  • Java Eye
  • Java Research
  • JavaRead
  • JavaWorldTW
  • Matrix
  • PHP100
  • PHPX
  • SpringSideWiKi
  • TheServerSide
  • TWPHP
  • 中国工作流论坛

项目管理

  • 管理人网

最新评论

View Post

WinForm DataGrid 的DataGridTableStyle用法

Part 1 自定义数据源方式的代码,首先在winform里拖一个DataGrid进去。
private void Form1_Load(object sender, System.EventArgs e)
        
{
            
//定义数据源--DataTable
            DataTable dt=new DataTable("mytable");
            
//添加列
            dt.Columns.Add("列1",typeof(String));
            dt.Columns.Add(
"列2",typeof(Int32));
            dt.Columns.Add(
"列3",typeof(Boolean));

            
//添加行
            DataRow row,row1;
            row
=dt.NewRow();
            row[
"列1"]="行1";
            row[
"列2"]=1;
            row[
"列3"]=true;
            dt.Rows.Add(row);
            row1
=dt.NewRow();
            row1[
"列1"]="行2";
            row1[
"列2"]=2;
            row1[
"列3"]=false;
            dt.Rows.Add(row1);

            
//为DataGrid添加数据源
            dataGrid1.DataSource=dt;

            
//定义DataGridTableStyle
            DataGridTableStyle ts=new DataGridTableStyle();
            ts.MappingName
=dt.TableName;  //映射style对应数据源的表名,很重要,否则无数据显示

            
//分别对列进行渲染
            int numColumns=dt.Columns.Count;
            dataGrid1.CaptionText
="DataGrid事例";  //指名DataGrid标题

            
//采用循环方式渲染前两列
            DataGridTextBoxColumn aColumnTextColumn;
            
for(int i=0;i<numColumns-1;i++)
            
{
                
//前两列绑定TextBox方式显示
                aColumnTextColumn=new DataGridTextBoxColumn();
                aColumnTextColumn.HeaderText
=dt.Columns[i].ColumnName;  //列头
                aColumnTextColumn.MappingName=dt.Columns[i].ColumnName; //映射数据源的列名,很重要,否则无数据显示

                
if (i==1)
                
{
                    
//规定Cell的高度和宽度,然后渲染
                    ts.PreferredColumnWidth=100;
                    ts.PreferredRowHeight
=20;
                }


                
//指名交替行的背景色
                ts.AlternatingBackColor=Color.LightGray;
                
//TableStyle的ColumnStyle列添加上面指定的TextBox
                ts.GridColumnStyles.Add(aColumnTextColumn);
            }


            
//用CheckBox的方式渲染第3列
            DataGridBoolColumn bc=new DataGridBoolColumn();
            bc.HeaderText
=dt.Columns[2].ColumnName;
            bc.MappingName
=dt.Columns[2].ColumnName;
            ts.PreferredColumnWidth
=100;
            ts.GridColumnStyles.Add(bc);

            
//DataGrid上添加上面定义的TableStyle
            dataGrid1.TableStyles.Add(ts);
        }

Part 2 用查询数据库的结果集作为数据源,首先在winform里拖一个datagrid。
private void Form2_Load(object sender, System.EventArgs e)
        
{
            DataSet ds
=BookingCar.Business.Facade.Order.QueryAllOrderStatus(); //查询数据库得到DataSet
            dataGrid1.DataSource=ds.Tables[0]; //设定数据源
            dataGrid1.CaptionText="DataGrid试验";  //设定DataGrid的标题

            DataGridTableStyle ts
=new DataGridTableStyle();  //定义TableStyle
            ts.MappingName=ds.Tables[0].TableName;   //映射表名称,重要
            ts.ReadOnly=false;     //整个DataGrid读写方式
            
            
//第一列
            DataGridTextBoxColumn tc=new DataGridTextBoxColumn();  //定义第一列用TextBox渲染
            tc.HeaderText="状态类型";   //改变列头的显示
            tc.MappingName=ds.Tables[0].Columns[0].ColumnName;  //映射列的名称,重要,实际就是查询select 对因的列
            tc.Alignment=HorizontalAlignment.Center;  //对齐方式
            tc.ReadOnly=true;    //指明这一列的为只读方式
            ts.PreferredColumnWidth=70;  //指明Cell宽度
            ts.PreferredRowHeight=20; //指名Cell高度
            ts.AlternatingBackColor=Color.LightGray;
            ts.GridColumnStyles.Add(tc); 
//为ColumnStyle添加上面的TextBox

            
//第二列
            tc=new DataGridTextBoxColumn();
            tc.HeaderText
="状态描述";
            tc.MappingName
=ds.Tables[0].Columns[1].ColumnName;
            ts.PreferredColumnWidth
=200;
            ts.PreferredRowHeight
=20;
            ts.AlternatingBackColor
=Color.LightGray;
            ts.GridColumnStyles.Add(tc);

            
//把TableStyle添加到DataGrid的tablestyle中
            dataGrid1.TableStyles.Add(ts);
        }

Part 3 使用DataGrid的属性面板。首先在winform里拖一个datagrid。

private void Form3_Load(object sender, System.EventArgs e)
        
{
            DataSet ds
=BookingCar.Business.Facade.Order.QueryAllOrderStatus();
            dataGrid1.DataSource
=ds.Tables[0];
        }

然后在TableStyle属性框内添加TableStyle,一般添加一个就够了,然后为TableStyle添加ColumnStyle,对应多个列。两个属性的mappingname都很重要,TableStyle的mappingname对应结果集的表名称,columnstyle的mappingname对应列的名称。
  

posted on 2005-09-19 11:11 MingIsMe 阅读(2029) 评论(0)  编辑  收藏 所属分类: 05 微软编程

 
Powered by:
BlogJava
Copyright © MingIsMe