Dieser Artikel wurde maschinell übersetzt. Wenn Sie die englische Version des Artikels anzeigen möchten, aktivieren Sie das Kontrollkästchen Englisch. Sie können den englischen Text auch in einem Popupfenster anzeigen, indem Sie den Mauszeiger über den Text bewegen.
Übersetzung
Englisch

IEditableObject-Schnittstelle

 

Veröffentlicht: Oktober 2016

Stellt Funktionen zur commit oder Rollback-Änderungen an ein Objekt, das als Datenquelle verwendet wird.

Namespace:   System.ComponentModel
Assembly:  System (in System.dll)

public interface IEditableObject

NameBeschreibung
System_CAPS_pubmethodBeginEdit()

Beginnt die Bearbeitung eines Objekts.

System_CAPS_pubmethodCancelEdit()

Verwirft Änderungen seit dem letzten BeginEdit aufrufen.

System_CAPS_pubmethodEndEdit()

Legt Änderungen seit dem letzten BeginEdit oder IBindingList.AddNew einen Aufruf an das zugrunde liegende Objekt.

Diese Schnittstelle wird in der Regel zum Erfassen der BeginEdit, EndEdit, und CancelEdit Semantik einer DataRowView.

Das folgende Beispiel stellt eine einfache Implementierung der IEditableObject Schnittstelle. Die Customer -Klasse speichert Kundeninformationen und kann als Auflistung für eine Kundendatenbank verwendet werden. In diesem Beispiel wird davon ausgegangen, dass Sie verwendet haben, die CustomerList -Klasse, die aus dem Beispiel gefunden werden, kann die IBindingList Klasse.

public class Customer : IEditableObject 
{

	struct CustomerData 
	{
		internal string id ;
		internal string firstName ;
		internal string lastName ;
	}

	private CustomersList parent;
	private CustomerData custData; 
	private CustomerData backupData; 
	private bool inTxn = false;

	// Implements IEditableObject
	void IEditableObject.BeginEdit() 
	{
		Console.WriteLine("Start BeginEdit");
		if (!inTxn) 
		{
			this.backupData = custData;
			inTxn = true;
			Console.WriteLine("BeginEdit - " + this.backupData.lastName);
		}
		Console.WriteLine("End BeginEdit");
	}

	void IEditableObject.CancelEdit() 
	{
		Console.WriteLine("Start CancelEdit");
		if (inTxn) 
		{
			this.custData = backupData;
			inTxn = false;
			Console.WriteLine("CancelEdit - " + this.custData.lastName);
		}
		Console.WriteLine("End CancelEdit");
	}

	void IEditableObject.EndEdit() 
	{
		Console.WriteLine("Start EndEdit" + this.custData.id + this.custData.lastName);
		if (inTxn) 
		{
			backupData = new CustomerData();
			inTxn = false;
			Console.WriteLine("Done EndEdit - " + this.custData.id + this.custData.lastName);
		}
		Console.WriteLine("End EndEdit");
	}

	public Customer(string ID) : base() 
	{
		this.custData = new CustomerData();
		this.custData.id = ID;
		this.custData.firstName = "";
		this.custData.lastName = "";
	}

	public string ID 
	{
		get 
		{
			return this.custData.id;
		}
	}

	public string FirstName 
	{
		get 
		{
			return this.custData.firstName;
		}
		set 
		{
			this.custData.firstName = value;
               this.OnCustomerChanged();
		}
	}

	public string LastName 
	{
		get 
		{
			return this.custData.lastName;
		}
		set 
		{
			this.custData.lastName = value;
               this.OnCustomerChanged();
		}
	}

	internal CustomersList Parent 
	{
		get 
		{
			return parent;
		}
		set 
		{
			parent = value ;
		}
	}

	private void OnCustomerChanged() 
	{
		if (!inTxn && Parent != null) 
		{
			Parent.CustomerChanged(this);
		}
	}

	public override string ToString() 
	{
		StringWriter sb = new StringWriter();
		sb.Write(this.FirstName);
		sb.Write(" ");
		sb.Write(this.LastName);
		return sb.ToString();
	}   
}

Universelle Windows-Plattform
Verfügbar seit 8
.NET Framework
Verfügbar seit 1.1
Portierbare Klassenbibliothek
Unterstützt in: portierbare .NET-Plattformen
Silverlight
Verfügbar seit 2.0
Windows Phone Silverlight
Verfügbar seit 7.0
Windows Phone
Verfügbar seit 8.1
Zurück zum Anfang
Anzeigen: