在同一列的DataGridView控件不呈现在初始化网格 [英] Controls in the same DataGridView column dont render while initializing grid
问题描述
&GOOD NBSP;                                                 BAD
< IMG SRC =http://i.stack.imgur.com/ifrKA.pngALT =在这里输入的形象描述>
我主持不同的控件在DataGridView中列。当我在同时添加控制I初始化网格中的控制显示为文本框(BAD)。如果我的控件添加在DataGridView已初始化后控件呈现正常(GOOD)。
公共Form1中()
{
的InitializeComponent();
ControlsInGridViewColumn(); //< - 呈现控件文本框
}
私人无效的button1_Click(对象发件人,EventArgs五)
{
ControlsInGridViewColumn(); //< - 不正确地呈现控制
}
私人无效ControlsInGridViewColumn()
{
DataTable的DT =新的DataTable();
dt.Columns.Add(名称);
为(INT J = 0; J< 10; J ++)
{
dt.Rows.Add();
}
this.dataGridView1.DataSource = DT;
this.dataGridView1.Columns [0] .WIDTH = 200;
的DataGridViewComboBoxCell ComboBoxCell =新的DataGridViewComboBoxCell();
ComboBoxCell.Items.AddRange(新的String [] {AAA,BBB,CCC});
this.dataGridView1 [0,0] = ComboBoxCell;
this.dataGridView1 [0,0]。价值=BBB;
DataGridViewTextBoxCell TextBoxCell =新DataGridViewTextBoxCell();
this.dataGridView1 [0,1] = TextBoxCell;
this.dataGridView1 [0,1] .value的=一些文本;
DataGridViewCheckBoxCell CheckBoxCell =新DataGridViewCheckBoxCell();
CheckBoxCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1 [0,2] = CheckBoxCell;
this.dataGridView1 [0,2]。价值= TRUE;
}
怎样才能使控件初始化过程中正确地呈现?
的(我动态地添加DataGridViews)。的
更新:雅各布谢列兹尼奥夫的回答适用于形式,但不是用户控件这正是我需要的...这里是如何重现它:
在表单
私人无效button3_Click(对象发件人,EventArgs五)
{
this.Controls.Add(新userCtrl());
}
用户控制:
公共部分类userCtrl:用户控件
{
公共userCtrl()
{
的InitializeComponent();
}
保护覆盖无效的OnLoad(EventArgs的发送)
{
ControlsInGridViewColumn();
base.OnLoad(E);
}
公共无效ControlsInGridViewColumn()
{
//相同的代码如上
}
}
这为我工作:
保护覆盖无效的OnLoad(EventArgs的发送)
{
ControlsInGridViewColumn(); //< - 不正确地呈现控制
base.OnLoad(E);
}
GOOD BAD
I'm hosting different controls in DataGridView column. When I add controls at the same time I initialize the grid the controls show as Textboxes (BAD). If I add the controls after the DataGridView has been initialized controls render correctly (GOOD).
public Form1()
{
InitializeComponent();
ControlsInGridViewColumn(); //<- renders controls as textboxes
}
private void button1_Click(object sender, EventArgs e)
{
ControlsInGridViewColumn(); //<- does correctly render controls
}
private void ControlsInGridViewColumn()
{
DataTable dt = new DataTable();
dt.Columns.Add("name");
for (int j = 0; j < 10; j++)
{
dt.Rows.Add("");
}
this.dataGridView1.DataSource = dt;
this.dataGridView1.Columns[0].Width = 200;
DataGridViewComboBoxCell ComboBoxCell = new DataGridViewComboBoxCell();
ComboBoxCell.Items.AddRange(new string[] { "aaa","bbb","ccc" });
this.dataGridView1[0, 0] = ComboBoxCell;
this.dataGridView1[0, 0].Value = "bbb";
DataGridViewTextBoxCell TextBoxCell = new DataGridViewTextBoxCell();
this.dataGridView1[0, 1] = TextBoxCell;
this.dataGridView1[0, 1].Value = "some text";
DataGridViewCheckBoxCell CheckBoxCell = new DataGridViewCheckBoxCell();
CheckBoxCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
this.dataGridView1[0, 2] = CheckBoxCell;
this.dataGridView1[0, 2].Value = true;
}
How does one make the controls render correctly during initialization?
(I'm adding DataGridViews dynamically).
UPDATE: Jacob Seleznev's answer works for Forms but not user controls which is what I need... Here is how to reproduce it:
In the Form:
private void button3_Click(object sender, EventArgs e)
{
this.Controls.Add(new userCtrl());
}
The user Control:
public partial class userCtrl : UserControl
{
public userCtrl()
{
InitializeComponent();
}
protected override void OnLoad(EventArgs e)
{
ControlsInGridViewColumn();
base.OnLoad(e);
}
public void ControlsInGridViewColumn()
{
//same code as above
}
}
This worked for me:
protected override void OnLoad(EventArgs e)
{
ControlsInGridViewColumn(); //<- does correctly render controls
base.OnLoad(e);
}
这篇关于在同一列的DataGridView控件不呈现在初始化网格的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!