DataGrid中出现在AddNew或EditItem事务过程不允许Deferrefresh报错

操作:在datagrid中快速点击某行某列,然后快速切换到其它页面再切回来,DataGrid会报错在编辑或新增时不能刷新数据。

在 AddNew 或 EditItem 事务过程中不允许“DeferRefresh”。

原因:在DataGrid编辑状态时,切换页面;此时,DataGrid仍在编辑状态,并未收集数据;当页签切回时,会重新为DataGrid绑定ItemsSource,但此时DataGrid在编辑状态,会报错,其实是编辑状态的DataGrid无法重新绑定数据;

解决方法:1.如果DataGrid表格本身就是不可编辑样式,则直接将IsReadOnly属性设置为true,即可。这样DataGrid不会出现Edit状态,也不会报错,但不确定在Add时,是否还会报错。

2.添加DataGrid UnLoaded事件

    void DataGrid_Unloaded(object sender, RoutedEventArgs e)
    {
        var grid = (DataGrid)sender;
        grid.CommitEdit(DataGridEditingUnit.Row, true);
	//或者
	grid .CancelEdit(DataGridEditingUnit.Row);   
}
  3.或者增加切换页签事件

	   
	WPFdataGrid.CancelEdit(); 

4.在DataGrid中添加一个鼠标按下事件 PreviewMouseDown

/// <summary>
        /// 鼠标按下事件,处理快速点击发生deferRefresh异常的处理
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void dtgSchemeApp_PreviewMouseDown(object sender, System.Windows.Input.MouseButtonEventArgs e)
        {
            if (IsUnderTabHeader(e.OriginalSource as DependencyObject))
                CommitTables(this.dtgSchemeApp);
        }

        private bool IsUnderTabHeader(DependencyObject control)
        {
            if (control is TabItem)
                return true;
            DependencyObject parent = VisualTreeHelper.GetParent(control);
            if (parent == null)
                return false;
            return IsUnderTabHeader(parent);
        }

        private void CommitTables(DependencyObject control)
        {
            if (control is DataGrid)
            {
                DataGrid grid = control as DataGrid;
                grid.CommitEdit(DataGridEditingUnit.Row, true);
                return;
            }
            int childrenCount = VisualTreeHelper.GetChildrenCount(control);
            for (int childIndex = 0; childIndex < childrenCount; childIndex++)
                CommitTables(VisualTreeHelper.GetChild(control, childIndex));
        }

 总而言之就是在DataGrid重新加载时,会刷新数据,这时要保证DataGrid不处于Edit状态。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值