DataGrid實現內容自動換行


這里有兩種實現方式:

一 用ElementStyle

  <data:DataGrid  GridLinesVisibility="None" AutoGenerateColumns="False" Loaded="DataGrid_Loaded" Height="300" Width="500">
<data:DataGrid.Columns>
<data:DataGridTextColumn Width="4*" Header="User Name" Binding="{Binding UserName}"/>
<data:DataGridTextColumn Width="1*" Header="Permissions" Binding="{Binding PermissionString}">
<data:DataGridTextColumn.ElementStyle>
<Style TargetType="TextBlock">
<Setter Property="TextWrapping" Value="Wrap"/>
</Style>
</data:DataGridTextColumn.ElementStyle>
</data:DataGridTextColumn>
</data:DataGrid.Columns>
</data:DataGrid>

Tips:一定要設置行高度才能實現換行的顯示,只能手動利用DataGrid.RowHeight屬性設置行高度。

缺點:每行的高度固定,不能根據內容多少自動設置高度。

二 用DataTemplate

<DataTemplate x:Key="TextDataTemplate">
<TextBlock TextWrapping="Wrap" Text="{Binding PermissionString}" ToolTipService.ToolTip="{Binding PermissionString}"/>
</DataTemplate>
<data:DataGrid  GridLinesVisibility="None" AutoGenerateColumns="False" Loaded="DataGrid_Loaded" Height="300" Width="500">
<data:DataGrid.Columns>
<data:DataGridTextColumn Width="4*" Header="User Name" Binding="{Binding UserName}"/>
<data:DataGridTemplateColumn CellTemplate="{StaticResource TextDataTemplate}" Header="Permissions" Width="1*"/>
</data:DataGrid.Columns>
</data:DataGrid>

能實現根據內容多少自動設置高度且換行。

換行效果如下:





免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM