我认为,当DataGrid中的文本框包含无效数据并被禁用时,我偶然发现了WPF中的错误。
当文本框包含无效数据并被禁用时,我可以通过在包含无效数据的文本框上单击两次来使数据(和绑定?)神奇地消失,单击行中的另一个元素,然后在文本框上单击两次无效数据。 我做了一个小例子来重现这个问题。如果您在121上单击两次,在55上单击一次,在121上单击两次121则应该消失(并且绑定将停止工作?)。任何人都可以确认这是一个错误,还是我做了一些愚蠢的事情?
WPF代码:
<Window x:Class="WpfApplication1.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="MainWindow" Height="350" Width="525">
<DataGrid ItemsSource="{Binding Path=Tests}" AutoGenerateColumns="False">
<DataGrid.Columns>
<DataGridTemplateColumn Header="Test header">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<TextBox IsEnabled="False" Text="{Binding Path=Text, UpdateSourceTrigger=PropertyChanged, ValidatesOnDataErrors=True}">
</TextBox>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
<DataGridTemplateColumn Header="Test header 2">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<TextBox IsEnabled="False" Text="{Binding Path=Text2, UpdateSourceTrigger=PropertyChanged, ValidatesOnDataErrors=True}">
</TextBox>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
</DataGrid.Columns>
</DataGrid>
C#代码:
using System;
using System.Windows;
using System.ComponentModel;
using System.Collections.ObjectModel;
namespace WpfApplication1
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
public ObservableCollection<Test> Tests {get;set;}
public MainWindow()
{
InitializeComponent();
this.DataContext = this;
Tests = new ObservableCollection<Test>();
Tests.Add(new Test());
}
}
public class Test : INotifyPropertyChanged, IDataErrorInfo
{
public string Text { get; set; }
public string Text2 { get; set; }
public Test()
{
Text = "121";
Text2 = "55";
}
public string Error
{
get { return null; }
}
public string this[string columnName]
{
get { return "WTF!!!"; }
}
public event PropertyChangedEventHandler PropertyChanged;
private void NotifyPropertyChanged(String info)
{
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs(info));
}
}
}
}