我想要Grid
和两列,其中在一列中我Label
在另一列TextBox
中显示值。但不幸的是我的标签和文本框是一个接一个地显示。我做错了什么?显示信息是否合适而优雅?也许你可以建议任何其他更好的方法吗?谢谢!
<StackPanel Grid.Row="0" Grid.Column="2" VerticalAlignment="Stretch">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*"/>
<ColumnDefinition Width="*"/>
</Grid.ColumnDefinitions>
<telerik:Label Grid.Column="0" Content="Name" Width="203" FontSize="16"/>
<telerik:Label Grid.Column="0" Content="Title" Width="203" FontSize="16"/>
<telerik:Label Grid.Column="0" Content="Phone" Width="203" FontSize="16"/>
<telerik:Label Grid.Column="0" Content="Email" Width="203" FontSize="16"/>
<telerik:Label Grid.Column="0" Content="Departament" Width="203" FontSize="16"/>
<TextBlock Grid.Column="1" x:Name="txtFullName" TextWrapping="Wrap" Height="26"/>
<TextBlock Grid.Column="1" x:Name ="txtTitle" TextWrapping="Wrap" Height="26"/>
<TextBlock Grid.Column="1" x:Name ="txtPhone" TextWrapping="Wrap" Height="26"/>
<TextBlock Grid.Column="1" x:Name ="txtEmail" TextWrapping="Wrap" Height="26"/>
<TextBlock Grid.Column="1" x:Name ="txtDepartment" TextWrapping="Wrap" Height="26"/>
</Grid>
</StackPanel>
答案 0 :(得分:1)
您需要将行添加到Grid
。目前,只有一行(因为你没有RowDefinitions
),所以每列中的所有项目将在单行中叠加在一起。
网格行的添加方式与添加列的方式大致相同,然后以相同的方式告诉控件它们属于哪一行。您可以添加如下行:
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*"/> <!-- * is the default width, so not required -->
<ColumnDefinition/> <!-- will be the same as above due to default of * -->
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="*"/> <!-- the * height is implied if not present -->
<RowDefinition Height="Auto"/> <!-- this will take up only as much space as necessary -->
</Grid.RowDefinitions>
<TextBox Grid.Column="0" Grid.Row="0" Text="Label 1"/>
<TextBox Grid.Column="0" Grid.Row="1" Text="Label 2"/>
<!-- etc... -->
</Grid>
高度为*的行将拉伸以填充可用空间(在具有*高度的所有行之间划分),高度为“自动”的行将缩小,以便仅占用显示其高度的必要空间内容。