只能将一个DataGrid行设置为可编程编辑

时间:2015-03-09 11:51:04

标签: c# wpf xaml datagrid

我使用数据库中的信息填充DataGrid。信息看似很好。我希望将所有内容保持为只读一列。我不希望该列标题可编辑。只有它下面的行。例如,根据下图,我希望能够编辑参与者行内容5,5,5和3。

我没有看到任何选项可以单独选择要设置为只读的行或列。我只看到一个选项,将整个DataGrid设置为只读。我试图循环并尝试将只读设置为所需的列但不能。请指教。谢谢。

enter image description here

看到一些示例,您可以通过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}"/>

2 个答案:

答案 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做了这个。