WPF的DataGrid编辑单元格回车往右拐的方法



    最后一个可编辑的单元格按下回车时增加一行个人感觉太繁琐了点  最好是直接给Grid加一行 而不是给对应的集合加一行,寻求更好的解决方案!

        /// <summary>
        /// Grid最后一列加行和往右拐
        /// </summary>
        /// <typeparam name="Tresult"></typeparam>
        /// <param name="dataGrid"></param>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        /// <param name="li"></param>
        public static void Grid_Right<Tresult>(this DataGrid dataGrid, object sender, KeyEventArgs e) where Tresult : class, new()
        {
            var uie = e.OriginalSource as UIElement;
            if (e.Key == Key.Enter)
            {
                e.Handled = true;
                uie.MoveFocus(new TraversalRequest(FocusNavigationDirection.Next));
                dataGrid.BeginEdit();
                if (dataGrid.CurrentColumn != null)
                {
                    if (dataGrid.CurrentColumn.IsReadOnly == true)
                    {

                        for (int b = dataGrid.CurrentColumn.DisplayIndex; b < dataGrid.Columns.Count; b++)
                        {
                            for (int k = 0; k < dataGrid.Columns.Count; k++)
                            {
                                if (dataGrid.Columns[k].DisplayIndex == b)
                                {
                                    if (dataGrid.Columns[k].IsReadOnly == false && dataGrid.Columns[k].Visibility == Visibility.Visible)
                                    {
                                        dataGrid.CurrentColumn = dataGrid.Columns[k];
                                        dataGrid.SelectedItem = dataGrid.CurrentItem;
                                        dataGrid.BeginEdit();
                                        return;
                                    }
                                    else if (k == dataGrid.Columns.Count - 1 && (dataGrid.Columns[k].IsReadOnly == true || dataGrid.Columns[k].Visibility == Visibility.Hidden))
                                    {
                                        if (dataGrid.SelectedIndex != dataGrid.Items.Count - 1)
                                        {
                                            dataGrid.SelectedIndex = dataGrid.SelectedIndex + 1;
                                            dataGrid.CurrentColumn = dataGrid.Columns[0];
                                            dataGrid.CurrentItem = dataGrid.SelectedItem;
                                            b = 0;
                                        }
                                        else
                                        {
                                           //PropertyInfo p = dataGrid.CurrentItem.GetType();
                                            ModelObservableCollection<Tresult> li = dataGrid.ItemsSource as ModelObservableCollection<Tresult>;
                                            li.Insert(dataGrid.SelectedIndex + 1, new Tresult());
                                            dataGrid.SelectedIndex = dataGrid.SelectedIndex + 1;
                                            dataGrid.CurrentColumn = dataGrid.Columns[0];
                                            dataGrid.CurrentItem = dataGrid.SelectedItem;
                                            b = 0;
                                        }

                                    }
                                }
                            }

                        }
                    }
                }
            }
        }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 WPF DataGrid编辑单元格,可以使用以下步骤: 1. 将 DataGrid 的属性 `IsReadOnly` 设置为 `False`,这样就可以允许用户编辑单元格。 2. 在 XAML 中,使用 DataGridTemplateColumn 模板列来定义一个可以编辑单元格。例如: ```xml <DataGridTemplateColumn Header="Name"> <DataGridTemplateColumn.CellTemplate> <DataTemplate> <TextBlock Text="{Binding Name}" /> </DataTemplate> </DataGridTemplateColumn.CellTemplate> <DataGridTemplateColumn.CellEditingTemplate> <DataTemplate> <TextBox Text="{Binding Name, UpdateSourceTrigger=PropertyChanged}" /> </DataTemplate> </DataGridTemplateColumn.CellEditingTemplate> </DataGridTemplateColumn> ``` 上述代码中,我们定义了一个 DataGridTemplateColumn 列,其中包含一个 CellTemplate 和一个 CellEditingTemplate。CellTemplate 用于显示单元格的值,而 CellEditingTemplate 用于编辑单元格的值。在这个例子中,我们显示了一个 TextBlock 来显示单元格的值,并且在编辑模式下使用了一个 TextBox 来允许用户编辑单元格的值。 3. 在 ViewModel 中实现 INotifyPropertyChanged 接口,并确保属性的 setter 中调用 PropertyChanged 事件。这是为了确保在单元格编辑时能够正确地更新数据源。 ```csharp public class PersonViewModel : INotifyPropertyChanged { private string _name; public string Name { get { return _name; } set { if (_name != value) { _name = value; OnPropertyChanged("Name"); } } } public event PropertyChangedEventHandler PropertyChanged; protected virtual void OnPropertyChanged(string propertyName = null) { PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName)); } } ``` 上述代码中,我们实现了一个 PersonViewModel,它包含一个 Name 属性,并且当 Name 属性发生变化时会触发 PropertyChanged 事件。 4. 在 DataGrid 的 ItemsSource 中绑定数据源,并确保每个单元格的 DataContext 都是一个 ViewModel 实例。这样,在编辑单元格时,WPF 就会自动更新 ViewModel 中的属性,并且在更新后重新绑定单元格的值。 ```xml <DataGrid ItemsSource="{Binding People}" AutoGenerateColumns="False"> <DataGrid.Columns> <DataGridTemplateColumn Header="Name" Width="*"> <DataGridTemplateColumn.CellTemplate> <DataTemplate> <TextBlock Text="{Binding Name}" /> </DataTemplate> </DataGridTemplateColumn.CellTemplate> <DataGridTemplateColumn.CellEditingTemplate> <DataTemplate> <TextBox Text="{Binding Name, UpdateSourceTrigger=PropertyChanged}" /> </DataTemplate> </DataGridTemplateColumn.CellEditingTemplate> </DataGridTemplateColumn> </DataGrid.Columns> </DataGrid> ``` 上述代码中,我们绑定了一个名为 People 的集合到 DataGrid 的 ItemsSource 属性,并且在 CellTemplate 和 CellEditingTemplate 中使用了 Name 属性来绑定单元格的值。注意,在编辑单元格时,我们使用了 UpdateSourceTrigger=PropertyChanged,这样在用户输入时可以立即更新数据源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值