我使用数据库中的信息填充DataGrid。信息看似很好。我希望将所有内容保持为只读一列。我不希望该列标题可编辑。只有它下面的行。例如,根据下图,我希望能够编辑参与者行内容5,5,5和3。
我没有看到任何选项可以单独选择要设置为只读的行或列。我只看到一个选项,将整个DataGrid设置为只读。我试图循环并尝试将只读设置为所需的列但不能。请指教。谢谢。
看到一些示例,您可以通过XAML单独说明哪些列是只读的,但这些是预定数据的手动输入。我试图使用自动生成的列填充DataGrid,数据来自数据库,我想以编程方式进行。
Connection connection = new Connection();
public static DataTable dt = new DataTable();
private void FillTable(DataGrid dataGrid)
{
//Connecting to database
connection.ConnectToDB(table, dt);
dataGrid.ItemsSource = dt.DefaultView;
foreach (DataGridColumn column in dataGrid1.Columns)
{
if (column.DisplayIndex == 1)
{
dataGrid1.IsReadOnly = true;
}
}
//dataGrid1.IsReadOnly = true;
}
XAML:
<DataGrid x:Name="dataGrid1" Canvas.Left="10" Canvas.Top="10" Height="auto" Width="auto" MaxHeight="400" AutoGenerateColumns="True" Style="{DynamicResource DataGridStyle1}"/>
答案 0 :(得分:2)
如果自动生成列,则处理DataGrid.AutoGeneratingColumn
。
private void OnAutoGeneratingColumn(object sender, DataGridAutoGeneratingColumnEventArgs e)
{
if (e.PropertyName != "Participants")
{ e.Column.IsReadOnly = true; }
}
并更改FillTable
方法:
private void FillTable(DataGrid dataGrid)
{
connection.ConnectToDB(table, dt);
dataGrid.ItemsSource = dt.DefaultView;
}
答案 1 :(得分:0)
将AutoGenerateColumns
- 属性设置为false,而不是在所需的可视化设计中提供所需的属性。
皮肤的小例子:
<GroupBox Grid.Row="2" Header="Items" Padding="5">
<GroupBox.Resources>
<Style TargetType="{x:Type DataGrid}">
<Style.Resources>
<SolidColorBrush x:Key="{x:Static SystemColors.HighlightBrushKey}" Color="#C2E58F" />
<Style TargetType="{x:Type DataGridCell}">
<Style.Triggers>
<Trigger Property="IsSelected" Value="True">
<Setter Property="Background" Value="#C2E58F" />
<Setter Property="Foreground" Value="Black" />
<Setter Property="BorderThickness" Value="0" />
</Trigger>
</Style.Triggers>
</Style>
</Style.Resources>
<Setter Property="BorderThickness" Value="0" />
<Setter Property="AutoGenerateColumns" Value="False" />
<Setter Property="AlternationCount" Value="2" />
<Setter Property="AlternatingRowBackground" Value="LightGray" />
<Setter Property="CanUserAddRows" Value="False" />
<Setter Property="CanUserDeleteRows" Value="False" />
<Setter Property="SelectionMode" Value="Single" />
<Setter Property="SelectionUnit" Value="FullRow" />
<Setter Property="FocusManager.IsFocusScope" Value="True" />
</Style>
</GroupBox.Resources>
<DataGrid ItemsSource="{Binding NameNotes, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay}"
AutoGenerateColumns="False">
<DataGrid.Columns>
<DataGridTemplateColumn Header="Firstname" Width="Auto" SortMemberPath="Firstname">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<TextBlock Text="{Binding Firstname}" VerticalAlignment="Center" Margin="3,1"/>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
<DataGridTemplateColumn.CellEditingTemplate>
<DataTemplate>
<TextBox Text="{Binding Firstname}" VerticalAlignment="Center" Margin="3,1"/>
</DataTemplate>
</DataGridTemplateColumn.CellEditingTemplate>
</DataGridTemplateColumn>
<DataGridTemplateColumn Header="Lastname" Width="Auto" SortMemberPath="Lastname">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<TextBlock Text="{Binding Lastname}" VerticalAlignment="Center" Margin="3,1"/>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
<DataGridTemplateColumn Header="Note" Width="*" SortMemberPath="Note">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<TextBlock Text="{Binding Note}" VerticalAlignment="Center" Margin="3,1" TextWrapping="WrapWithOverflow"/>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
</DataGrid.Columns>
</DataGrid>
</GroupBox>
要编辑一列,您必须为此列提供CellEditingTemplate
。我在我的例子中为Firstname-Column做了这个。