Diese Dokumentation wurde archiviert und wird nicht länger gepflegt.

StateManagedCollection.SetDirtyObject-Methode

Beim Überschreiben in einer abgeleiteten Klasse wird ein in der Auflistung enthaltenes object angewiesen, seinen gesamten Zustand im Ansichtszustand aufzuzeichnen, anstatt nur die Änderungsinformationen aufzuzeichnen.

Namespace: System.Web.UI
Assembly: System.Web (in system.web.dll)

protected abstract void SetDirtyObject (
	Object o
)
protected abstract void SetDirtyObject (
	Object o
)
protected abstract function SetDirtyObject (
	o : Object
)
Nicht zutreffend.

Parameter

o

Der IStateManager, der vollständig serialisiert werden soll.

Die SetDirtyObject-Methode wird intern von den Methoden System.Web.UI.IStateManager.SaveViewState, System.Collections.IList.Add und System.Collections.IList.Insert aufgerufen.

Im folgenden Codebeispiel wird veranschaulicht, wie eine stark typisierte StateManagedCollection-Klasse die abstrakte SetDirtyObject-Methode implementiert. Die CycleCollection speichert ihre Ansichtszustandsinformationen mithilfe eines StateBag-Objekts und delegiert den Aufruf einfach an die SetDirty-Methode des StateBag-Objekts. Dieses Codebeispiel ist Teil eines umfangreicheren Beispiels für die StateManagedCollection-Klasse.

//////////////////////////////////////////////////////////////
//
// The strongly typed CycleCollection class is a collection
// that contains Cycle class instances, which implement the
// IStateManager interface.
//
//////////////////////////////////////////////////////////////
[AspNetHostingPermission(SecurityAction.Demand, 
    Level=AspNetHostingPermissionLevel.Minimal)]
public sealed class CycleCollection : StateManagedCollection {
    
    private static readonly Type[] _typesOfCycles 
        = new Type[] { typeof(Bicycle), typeof(Tricycle) };

    protected override object CreateKnownType(int index) {
        switch(index) {
            case 0:
                return new Bicycle();
            case 1:
                return new Tricycle();                    
            default:
                throw new ArgumentOutOfRangeException("Unknown Type");
        }            
    }

    protected override Type[] GetKnownTypes() {
        return _typesOfCycles;
    }

    protected override void SetDirtyObject(object o) {
        ((Cycle)o).SetDirty();
    }

}

Windows 98, Windows Server 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile für Pocket PC, Windows Mobile für Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition

Microsoft .NET Framework 3.0 wird unter Windows Vista, Microsoft Windows XP SP2 und Windows Server 2003 SP1 unterstützt.

.NET Framework

Unterstützt in: 3.0, 2.0
Anzeigen: