IHierarchyData.GetParent Metodo

Definizione

Ottiene un oggetto IHierarchyData che rappresenta il nodo padre del nodo gerarchico corrente.Gets an IHierarchyData object that represents the parent node of the current hierarchical node.

public:
 System::Web::UI::IHierarchyData ^ GetParent();
public System.Web.UI.IHierarchyData GetParent ();
abstract member GetParent : unit -> System.Web.UI.IHierarchyData
Public Function GetParent () As IHierarchyData

Restituisce

Oggetto IHierarchyData che rappresenta il nodo padre del nodo gerarchico corrente.An IHierarchyData object that represents the parent node of the current hierarchical node.

Esempi

Nell'esempio di codice riportato di seguito viene illustrato GetParent come implementare il metodo in una classe IHierarchyData che implementa l'interfaccia.The following code example demonstrates how to implement the GetParent method in a class that implements the IHierarchyData interface. La FileSystemHierarchyData classe esegue il wrapping FileSystemInfo di un oggetto e GetParent l'implementazione del metodo controlla il tipo FileSystemInfo dell'oggetto e restituisce l'oggetto padre appropriato in base al tipo.The FileSystemHierarchyData class wraps a FileSystemInfo object, and the GetParent method implementation checks the type of the FileSystemInfo object, and returns the appropriate parent object based on the type. Questo esempio di codice fa parte di un esempio più ampio fornito IHierarchyData per l'interfaccia HierarchicalDataSourceControl e la classe.This code example is part of a larger example provided for the IHierarchyData interface and the HierarchicalDataSourceControl class.

public IHierarchicalEnumerable GetChildren()
{
    FileSystemHierarchicalEnumerable children =
        new FileSystemHierarchicalEnumerable();

    if (typeof(DirectoryInfo) == fileSystemObject.GetType())
    {
        DirectoryInfo temp = (DirectoryInfo)fileSystemObject;
        foreach (FileSystemInfo fsi in temp.GetFileSystemInfos())
        {
            children.Add(new FileSystemHierarchyData(fsi));
        }
    }
    return children;
}

public IHierarchyData GetParent()
{
    FileSystemHierarchicalEnumerable parentContainer =
        new FileSystemHierarchicalEnumerable();

    if (typeof(DirectoryInfo) == fileSystemObject.GetType())
    {
        DirectoryInfo temp = (DirectoryInfo)fileSystemObject;
        return new FileSystemHierarchyData(temp.Parent);
    }
    else if (typeof(FileInfo) == fileSystemObject.GetType())
    {
        FileInfo temp = (FileInfo)fileSystemObject;
        return new FileSystemHierarchyData(temp.Directory);
    }
    // If FileSystemObj is any other kind of FileSystemInfo, ignore it.
    return null;
}
    Public Overridable Function GetChildren() _
        As IHierarchicalEnumerable _
        Implements IHierarchyData.GetChildren

        Dim children As New FileSystemHierarchicalEnumerable()

        If GetType(DirectoryInfo) Is fileSystemObject.GetType() Then
            Dim temp As DirectoryInfo = _
                CType(fileSystemObject, DirectoryInfo)
            Dim fsi As FileSystemInfo
            For Each fsi In temp.GetFileSystemInfos()
                children.Add(New FileSystemHierarchyData(fsi))
            Next fsi
        End If
        Return children
    End Function 'GetChildren


    Public Overridable Function GetParent() As IHierarchyData _
     Implements IHierarchyData.GetParent
        Dim parentContainer As New FileSystemHierarchicalEnumerable()

        If GetType(DirectoryInfo) Is fileSystemObject.GetType() Then
            Dim temp As DirectoryInfo = _
                CType(fileSystemObject, DirectoryInfo)
            Return New FileSystemHierarchyData(temp.Parent)
        ElseIf GetType(FileInfo) Is fileSystemObject.GetType() Then
            Dim temp As FileInfo = CType(fileSystemObject, FileInfo)
            Return New FileSystemHierarchyData(temp.Directory)
        End If
        ' If FileSystemObj is any other kind of FileSystemInfo, ignore it.
        Return Nothing
    End Function 'GetParent
End Class

Commenti

L' IHierarchyData interfaccia non definisce una proprietà HasParent convenience, quindi i chiamanti devono controllare il valore restituito GetParent del metodo per null per determinare se il nodo corrente IHierarchyData è il nodo radice dei dati gerarchici. struttura a cui appartiene il nodo.The IHierarchyData interface does not define a HasParent convenience property, so callers must check the return value of the GetParent method for null to determine whether the current IHierarchyData node is the root node of the hierarchical data structure to which the node belongs.

Si applica a

Vedi anche