急急急!在线等,Winform中DataGrid增加Checkbox选择列的问题(VS2003)

insnowind 2006-11-13 09:53:47
我想在DataGrid中插入第一列作为选择列,这是我的代码,为什么显示不出来?
DataGridBoolColumn的MapingName属性是不是一定要,我这里只是作为选择标记,并不需要影射到某一列上,应该怎么做,看了很多文章都不行,高手救我!!!!

DataGridTableStyle ts = new DataGridTableStyle();

DataGridTextBoxColumn aColumnTextColumn;
DataGrid1.DataSource = dtGrid;
ts.MappingName = dtGrid.TableName;
int numCols = dtGrid.Columns.Count;
DataGrid1.CaptionText = "生产计划列表";

DataGridColumnStyle dcSelect = new DataGridBoolColumn();
dcSelect.HeaderText = "选择";
dcSelect.MappingName = "";
//dcSelect.Alignment = System.Windows.Forms.HorizontalAlignment.Center;
dcSelect.Width = 50;
//dcSelect.AllowNull = false;
ts.GridColumnStyles.Add(dcSelect);
...全文
352 15 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
yuanzhihua520 2006-11-30
  • 打赏
  • 举报
回复
up
insnowind 2006-11-13
  • 打赏
  • 举报
回复
加点分!
insnowind 2006-11-13
  • 打赏
  • 举报
回复
aColumnTextColumn.Width = 100;
DateTimePicker dtp = new DateTimePicker();
dtp.Dock= DockStyle.Fill;
dtp.Cursor= Cursors.Arrow;
dtp.ValueChanged+=new EventHandler(this.dtg_ValueChanged);//日期获取变化
aColumnTextColumn.TextBox.Controls.Add(dtp);
=============================================================================
这样和那个有一点区别,这个是填充值,那个是这一列根本显示不出来,应该怎么做,请指教:)
jacobwc 2006-11-13
  • 打赏
  • 举报
回复
参考我以前做的嵌入datetimePicker
aColumnTextColumn.Width = 100;
DateTimePicker dtp = new DateTimePicker();
dtp.Dock= DockStyle.Fill;
dtp.Cursor= Cursors.Arrow;
dtp.ValueChanged+=new EventHandler(this.dtg_ValueChanged);//日期获取变化
aColumnTextColumn.TextBox.Controls.Add(dtp);
jacobwc 2006-11-13
  • 打赏
  • 举报
回复
小强说的不是winform
insnowind 2006-11-13
  • 打赏
  • 举报
回复
怎么没有这个事件呢?
ItemDataBound
九章落地 2006-11-13
  • 打赏
  • 举报
回复
LZ这种插入方式更方便些:
private void DataGrid1_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
{
if ((e.Item.ItemType == ListItemType.Item) ||
(e.Item.ItemType == ListItemType.AlternatingItem) ||
(e.Item.ItemType == ListItemType.SelectedItem) )
{
CheckBox cb ;
//加选择框
cb = new CheckBox();
e.Item.Cells[0].Controls.Add(cb);
}
insnowind 2006-11-13
  • 打赏
  • 举报
回复
顶顶顶!
insnowind 2006-11-13
  • 打赏
  • 举报
回复
主要是这几句:
DataGridColumnStyle dcSelect = new DataGridBoolColumn();
dcSelect.HeaderText = "选择";
dcSelect.MappingName = "";
//dcSelect.Alignment = System.Windows.Forms.HorizontalAlignment.Center;
dcSelect.Width = 50;
//dcSelect.AllowNull = false;
ts.GridColumnStyles.Add(dcSelect);

所有列定义完之后,还有这句:
DataGrid1.TableStyles.Add(ts);

所以应该是DataGridBoolColumn没有定义好,应该是怎么回事,谢谢!
insnowind 2006-11-13
  • 打赏
  • 举报
回复
还是要靠自己整!
insnowind 2006-11-13
  • 打赏
  • 举报
回复
myDb db1 = new myDb() ;
DataTable dtGrid = db1.ExecuteToDataTable(strSQL) ;

DataColumn checkCol = new DataColumn();
checkCol.ColumnName = "CheckState";
checkCol.DefaultValue = "0";
checkCol.AllowDBNull = false;

dtGrid.Columns.Add(checkCol);


//=======================================
DataGridTableStyle ts = new DataGridTableStyle();

DataGridTextBoxColumn aColumnTextColumn;
DataGrid1.DataSource = dtGrid;
ts.MappingName = dtGrid.TableName;
int numCols = dtGrid.Columns.Count;
DataGrid1.CaptionText = "生产计划列表";

DataGridColumnStyle dcSelect = new DataGridBoolColumn();
dcSelect.HeaderText = "选择";
dcSelect.MappingName = "CheckState";
dcSelect.Alignment = System.Windows.Forms.HorizontalAlignment.Center;
dcSelect.Width = 50;
((DataGridBoolColumn)dcSelect).AllowNull = false;
dcSelect.
ts.GridColumnStyles.Add(dcSelect);
===============================================================================
我这样做了之后,出来是出来了,为什么都是默认选中的灰色,而且点一下就会自动生成一个空的行,点一下多一个
Knight94 2006-11-13
  • 打赏
  • 举报
回复
如果直接向DataGrid种进行插入,不设置Mapping是不行的。

替换做法,你创建一个临时列,用于显示Checkbox,而且这也不麻烦。
insnowind 2006-11-13
  • 打赏
  • 举报
回复
myDb db1 = new myDb() ;
DataTable dtGrid = db1.ExecuteToDataTable(strSQL) ;
DataGridTableStyle ts = new DataGridTableStyle();

DataGridTextBoxColumn aColumnTextColumn;
DataGrid1.DataSource = dtGrid;
ts.MappingName = dtGrid.TableName;
int numCols = dtGrid.Columns.Count;
DataGrid1.CaptionText = "生产计划列表";

DataGridColumnStyle dcSelect = new DataGridBoolColumn();
dcSelect.HeaderText = "选择";
dcSelect.MappingName = "";
dcSelect.Alignment = System.Windows.Forms.HorizontalAlignment.Center;
dcSelect.Width = 50;
dcSelect.AllowNull = false;
ts.GridColumnStyles.Add(dcSelect);

int loopFlag = 0;
while (loopFlag < numCols)
{
aColumnTextColumn = new DataGridTextBoxColumn();
switch (loopFlag)
{
case 0 :
aColumnTextColumn.HeaderText = "编号";
aColumnTextColumn.Width = 50;
break;
case 1 :
aColumnTextColumn.HeaderText = "市场名称";
aColumnTextColumn.Width = 200;
break;
case 2 :
//其他的省略了
}
aColumnTextColumn.NullText = "";
aColumnTextColumn.ReadOnly = true;
aColumnTextColumn.Alignment=System.Windows.Forms.HorizontalAlignment.Center;
aColumnTextColumn.MappingName = dtGrid.Columns[loopFlag].ColumnName;
ts.GridColumnStyles.Add(aColumnTextColumn);
loopFlag++;
}

DataGrid1.TableStyles.Add(ts);
insnowind 2006-11-13
  • 打赏
  • 举报
回复
myDb db1 = new myDb() ;
DataTable dtGrid = db1.ExecuteToDataTable(strSQL) ;

//=======================================
DataGridTableStyle ts = new DataGridTableStyle();

DataGridTextBoxColumn aColumnTextColumn;
DataGrid1.DataSource = dtGrid;
ts.MappingName = dtGrid.TableName;
int numCols = dtGrid.Columns.Count;
DataGrid1.CaptionText = "生产计划列表";

DataGridColumnStyle dcSelect = new DataGridBoolColumn();
dcSelect.HeaderText = "选择";
dcSelect.MappingName = "";//是不是这里的问题
dcSelect.Alignment = System.Windows.Forms.HorizontalAlignment.Center;
dcSelect.Width = 50;
dcSelect.AllowNull = false;
ts.GridColumnStyles.Add(dcSelect);

int loopFlag = 0;
while (loopFlag < numCols)
{
aColumnTextColumn = new DataGridTextBoxColumn();
switch (loopFlag)
{
case 0 :
aColumnTextColumn.HeaderText = "编号";
aColumnTextColumn.Width = 50;
break;
case 1 :
aColumnTextColumn.HeaderText = "市场名称";
aColumnTextColumn.Width = 200;
break;
case 2 :
aColumnTextColumn.HeaderText = "档位号码";
aColumnTextColumn.Width = 80;
break;
//其他的省略了
}
aColumnTextColumn.NullText = "";
aColumnTextColumn.ReadOnly = true;
aColumnTextColumn.Alignment=System.Windows.Forms.HorizontalAlignment.Center;
aColumnTextColumn.MappingName = dtGrid.Columns[loopFlag].ColumnName;
ts.GridColumnStyles.Add(aColumnTextColumn);
loopFlag++;
}

DataGrid1.TableStyles.Add(ts);
Knight94 2006-11-13
  • 打赏
  • 举报
回复
How can I put a checkbox in a column of my DataGrid?
http://www.syncfusion.com/FAQ/WindowsForms/FAQ_c44c.aspx#q754q
访问真八字排盘系统介绍: 1、八字排盘 八字排盘是将年月日时按照天干地支的形式进行排,一个时间单位代表了一个柱。八字由年柱、月柱、日柱和时柱共四个柱组成,也被称为四柱八字。八字学基于国阴阳五行、天干地支与刑冲克害、以及民间盲派的神煞论等方式,进一步预测爱情顺遂、工作高低、姻缘好坏、财富高低、学业成就、身体健康等事的学问。 八字排盘由以下元素组合:年月日时四柱、大运干支、胎元 、流年干支、十神、地势、神煞等。生辰八字不只是把干支历计算出来,而还要遵守月令、节令的强弱,时辰的阴阳变化进行校正。排盘分析,就是根据出生者的性别、天干地支的阴阳五行关系、进一步推算出来的一套方法论,给预测者做人生吉凶的参考数据,在未来事业、财运、婚姻、家庭等问题时,能做出风险较低的决策。 八字排盘怎么看 八字排盘由年、月、日、时四柱组成,每柱包含一个天干和一个地支,共八个字。年柱代表出生的年份,月柱代表出生的月份,日柱代表出生的日期,时柱则代表出生的时辰。每个柱的干支组合都会对个人的命运产生影响。天干地支旁边标注的正财、偏财、偏印、正印、比肩、劫财、食神、伤官、正官、七杀等,称为十神。 2、八字排盘软件介绍 我们是腾讯云市场金牌合作伙伴,广州正规软件开发公司,开发的八字排盘系统数据最全面精准,我们八字排盘采用最精确的排盘程序,而且运用“真太阳时”,进行更精确的时间划分。大家都知道我们使用的北京时间,是统一规定的标准时间。而八字排盘需要相对于太阳方位的天文时间,即平太阳时。我们国家地大物博,北京时间19时,哈尔滨已经夜幕降临,而新疆却还是太阳高挂,这时哈尔滨的天文时间可能在20:00以后,而新疆的天文时间可能在16时以前。北京时间是东经120度经线的平太阳时,如果您出生地的经度与北京时间所处的经度差异较大,或者处于单数时间点的前后,比如6点差一刻,8点,10点15分等

111,097

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧