我基于stackpanel内的按钮单击动态添加文本框。但是在UI中看不到文本框。 以下是用于在stackpanel中创建文本框的代码。
public void GenerateControls()
{
TextBox txtNumber = new TextBox();
txtNumber.Name = "txtNumber";
txtNumber.Text = "1776";
txtNumber.Background= Brushes.Red;
panel1.Children.Add(txtNumber);
}
为什么它不可见.. ??这里是stackpanel的XAML部分
<StackPanel Name="panel1" Grid.Column="1" HorizontalAlignment="Left" Height="151" Margin="427,60,0,0" Grid.Row="2" VerticalAlignment="Top" Width="216">
<StackPanel Height="144">
</StackPanel>
</StackPanel>
答案 0 :(得分:1)
如果要动态添加控件,请不要限制要添加的容器的高度(甚至宽度)。
更新您的XAML以获得自动高度/宽度。
<StackPanel Name="panel1"
Grid.Column="1"
Height="Auto"
Width="Auto"
Margin="427,60,0,0"
Grid.Row="2"
VerticalAlignment="Top"
HorizontalAlignment="Left" >
<StackPanel Height="144">
</StackPanel>
</StackPanel>
此外,添加新子项后,请确保更新StackPanel
布局。
public void GenerateControls()
{
TextBox txtNumber = new TextBox();
txtNumber.Name = "txtNumber";
txtNumber.Text = "1776";
txtNumber.Background= Brushes.Red;
panel1.Children.Add(txtNumber);
panel1.UpdateLayout();
}
答案 1 :(得分:1)
在您的xaml代码中,您的&#39;面板中有一个堆栈面板,它将是&#39; panel&#39;的第一个孩子。
它的高度是144px。你的面板1&#39;是151像素。
因此,当您将文本框添加到&#39;面板&#39;时,它们将显示在144px堆栈面板后面。
只显示7px。因此它们不会显示在您的窗口上。