0

我正在尝试让 DataContract Serializer 与我的班级之一一起工作。

这里是 :

public class MyOwnObservableCollection<T> : ObservableCollection<T>, IDisposable
    where T : IObjectWithChangeTracker, INotifyPropertyChanged
{
    protected List<T> removedItems;

    [DataMember]
    public List<T> RemovedItems 
    {
    get { return this.removedItems;} 
    set { this.removedItems = value;}
    }
    // Other code removed for simplification
    // ...
    //
}

当您从 ObservableCollection 中删除项目时,请务必了解 RemovedItems 列表会自动填充。

现在使用 DataContractSerializer 序列化此类的一个实例,并使用以下代码在 removedItems 列表中具有一个元素:

MyOwnObservableCollection<Test> _Test = new MyOwnObservableCollection<Test>();
DataContractSerializer dcs = new DataContractSerializer(typeof(MyOwnObservableCollection<Test>));
XmlWriterSettings settings = new XmlWriterSettings() { Indent = true };
string fileName = @"Test.xml";

Insurance atest = new Test();
atest.Name = @"sfdsfsdfsff";
_Test.Add(atest);
_Test.RemoveAt(0); // The Iitem in the ObservableCollection is moved to the RemovedItems List/
using (var w = XmlWriter.Create(fileName, settings))
{
    dcs.WriteObject(w, _Test);
}

以 XML 文件中的任何内容结尾:

<?xml version="1.0" encoding="utf-8"?>
<ArrayOfTest xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="MyNameSpace" />

为什么这个公共财产被忽视了?我在这里错过了什么?

TIA。

4

1 回答 1

2

这里的问题是您的类是从集合派生的,因此,DataContractSerializer仅序列化其项目,而不是任何额外的属性,如此处所述:使用 CollectionDataContract 时没有属性

一种解决方法是使用原始(继承的)集合作为属性,而不是从它继承:

public class MyOwnObservableCollection<T> : IDisposable
    where T : IObjectWithChangeTracker, INotifyPropertyChanged
{
   readonly ObservableCollection<T> originalCollection = new ObservableCollection<T>();
   protected List<T> removedItems = = new List<T>();

   [DataMember]
   public List<T> RemovedItems 
   {
      get { return this.removedItems;} 
      set { this.removedItems = value;}
   }

   [DataMember]
   public ObservableCollection<T> OriginalCollection  
   {
      get { return this.originalCollection; }
   }

   // ...
}
于 2012-11-23T07:45:33.240 回答