AutomationElement.CachedChildren Eigenschap

Definitie

Hiermee haalt u de onderliggende elementen in de cache op.AutomationElement

public:
 property System::Windows::Automation::AutomationElementCollection ^ CachedChildren { System::Windows::Automation::AutomationElementCollection ^ get(); };
public System.Windows.Automation.AutomationElementCollection CachedChildren { get; }
member this.CachedChildren : System.Windows.Automation.AutomationElementCollection
Public ReadOnly Property CachedChildren As AutomationElementCollection

Waarde van eigenschap

De verzameling onderliggende elementen. Deze verzameling kan leeg zijn als het element geen onderliggende elementen heeft.

Uitzonderingen

De gebruikersinterface voor de AutomationElement app bestaat niet meer.

Er is geen aanvraag gedaan om de onderliggende elementen van dit element in de cache op te plaatsen.

Voorbeelden

In het volgende voorbeeld wordt een keuzelijstelement verkregen van het bovenliggende vensterelement terwijl een CacheRequest actief element is en TreeScope is Children. De opgegeven eigenschappen van de onderliggende elementen (dat wil gezegd de lijstitems) worden opgeslagen in de cache en kunnen worden opgehaald uit de CachedChildren keuzelijst.

/// <summary>
/// Gets a list box element and caches the Name property of its children (the list items).
/// </summary>
/// <param name="elementMain">The UI Automation element for the parent window.</param>
void CachePropertiesWithScope(AutomationElement elementMain)
{
    AutomationElement elementList;

    // Set up the CacheRequest.
    CacheRequest cacheRequest = new CacheRequest();
    cacheRequest.Add(AutomationElement.NameProperty);
    cacheRequest.TreeScope = TreeScope.Element | TreeScope.Children;

    // Activate the CacheRequest and get the element. Note that the scope of the CacheRequest
    // is in relation to the object being retrieved: the list box and its children are 
    // cached, not the main window and its children.
    using (cacheRequest.Activate())
    {
        // Load the list element and cache the specified properties for its descendants.
        Condition cond = new PropertyCondition(AutomationElement.ControlTypeProperty, ControlType.List);
        elementList = elementMain.FindFirst(TreeScope.Children, cond);
    }
    if (elementList == null) return;

    // The following illustrates that the children of the list are in the cache.
    foreach (AutomationElement listItem in elementList.CachedChildren)
    {
        Console.WriteLine(listItem.Cached.Name);
    }

    // The following call raises an exception, because the IsEnabled property was not cached.
    /*** Console.WriteLine(listItem.Cached.IsEnabled); ***/

    // The following illustrates that because the list box itself was cached, it is now
    // available as the CachedParent of each list item.
    AutomationElement child = elementList.CachedChildren[0];
    Console.WriteLine(child.CachedParent.Cached.Name);
}
''' <summary>
''' Gets a list box element and caches the Name property of its children (the list items).
''' </summary>
''' <param name="elementMain">The UI Automation element for the parent window.</param>
Sub CachePropertiesWithScope(ByVal elementMain As AutomationElement)
    Dim elementList As AutomationElement

    ' Set up the CacheRequest.
    Dim cacheRequest As New CacheRequest()
    cacheRequest.Add(AutomationElement.NameProperty)
    cacheRequest.TreeScope = TreeScope.Element Or TreeScope.Children

    ' Activate the CacheRequest and get the element. Note that the scope of the CacheRequest
    ' is in relation to the object being retrieved: the list box and its children are 
    ' cached, not the main window and its children.
    Using cacheRequest.Activate()
        ' Load the list element and cache the specified properties for its descendants.
        Dim myCondition As New PropertyCondition(AutomationElement.ControlTypeProperty, ControlType.List)
        elementList = elementMain.FindFirst(TreeScope.Children, myCondition)

        If elementList Is Nothing Then
            Return
        End If

        ' The following illustrates that the children of the list are in the cache.
        Dim listItem As AutomationElement
        For Each listItem In elementList.CachedChildren
            Console.WriteLine(listItem.Cached.Name)
        Next listItem

        ' The following call raises an exception, because the IsEnabled property was not cached.
        '** Console.WriteLine(listItem.Cached.IsEnabled) **

        ' The following illustrates that because the list box itself was cached, it is now
        ' available as the CachedParent of each list item.
        Dim child As AutomationElement = elementList.CachedChildren(0)
        Console.WriteLine(child.CachedParent.Cached.Name)
    End Using
End Sub

Opmerkingen

De weergave van de geretourneerde verzameling wordt bepaald door de TreeFilter voorwaarde die CacheRequest actief was toen dit AutomationElement object werd verkregen.

Kinderen worden alleen in de cache opgeslagen als het bereik van de CacheRequest opgenomen Subtree, Childrenof Descendants.

Als de opgegeven onderliggende items op dit niveau in de CacheRequest cache moeten worden opgeslagen, maar er geen onderliggende items zijn, is de waarde van deze eigenschap 0. Als er echter geen aanvraag is gedaan om onderliggende objecten op dit niveau in de cache op te cachen, wordt er een uitzondering gegenereerd door een poging om de eigenschap op te halen.

Van toepassing op

Zie ook