SiteMapNodeItemType Wyliczenie

Definicja

Wyliczenie SiteMapNodeItemType jest używane przez kontrolkę SiteMapPath do identyfikowania typu węzła SiteMapNodeItem w hierarchii węzłów.

public enum class SiteMapNodeItemType
public enum SiteMapNodeItemType
type SiteMapNodeItemType = 
Public Enum SiteMapNodeItemType
Dziedziczenie
SiteMapNodeItemType

Pola

Current 2

Aktualnie wyświetlona strona w ścieżce nawigacji witryny.

Parent 1

Węzeł nadrzędny aktualnie wyświetlanej strony w ścieżce nawigacji witryny. Węzeł nadrzędny to dowolny węzeł, który znajduje się między węzłem głównym a bieżącym węzłem w hierarchii nawigacji.

PathSeparator 3

Separator ścieżki nawigacji mapy witryny. Domyślnym separatorem kontrolki SiteMapPath jest znak ">".

Root 0

Górny węzeł hierarchii nawigacji lokacji. Może istnieć tylko jeden węzeł główny.

Przykłady

W poniższym przykładzie pokazano, jak wywołać metodę SiteMapPath.OnItemCreated po utworzeniu SiteMapPath.InitializeItem SiteMapNodeItem metody w ramach metody . Ten przykład jest częścią większego przykładu udostępnionego SiteMapPath dla klasy.

private void AddDropDownListAfterCurrentNode(SiteMapNodeItem item) {

    SiteMapNodeCollection childNodes = item.SiteMapNode.ChildNodes;

    // Only do this work if there are child nodes.
    if (childNodes != null) {

        // Add another PathSeparator after the CurrentNode.
        SiteMapNodeItem finalSeparator =
            new SiteMapNodeItem(item.ItemIndex,
                                SiteMapNodeItemType.PathSeparator);

        SiteMapNodeItemEventArgs eventArgs =
            new SiteMapNodeItemEventArgs(finalSeparator);

        InitializeItem(finalSeparator);
        // Call OnItemCreated every time a SiteMapNodeItem is
        // created and initialized.
        OnItemCreated(eventArgs);

        // The pathSeparator does not bind to any SiteMapNode, so
        // do not call DataBind on the SiteMapNodeItem.
        item.Controls.Add(finalSeparator);

        // Create a DropDownList and populate it with the children of the
        // CurrentNode. There are no styles or templates that are applied
        // to the DropDownList control. If OnSelectedIndexChanged is raised,
        // the event handler redirects to the page selected.
        // The CurrentNode has child nodes.
        DropDownList ddList = new DropDownList();
        ddList.AutoPostBack = true;

        ddList.SelectedIndexChanged += new EventHandler(this.DropDownNavPathEventHandler);

        // Add a ListItem to the DropDownList for every node in the
        // SiteMapNodes collection.
        foreach (SiteMapNode node in childNodes) {
            ddList.Items.Add(new ListItem(node.Title, node.Url));
        }

        item.Controls.Add(ddList);
    }
}
Private Sub AddDropDownListAfterCurrentNode(item As SiteMapNodeItem)

   Dim childNodes As SiteMapNodeCollection = item.SiteMapNode.ChildNodes

   ' Only do this work if there are child nodes.
   If Not (childNodes Is Nothing) Then

      ' Add another PathSeparator after the CurrentNode.
      Dim finalSeparator As New SiteMapNodeItem(item.ItemIndex, SiteMapNodeItemType.PathSeparator)

      Dim eventArgs As New SiteMapNodeItemEventArgs(finalSeparator)

      InitializeItem(finalSeparator)
      ' Call OnItemCreated every time a SiteMapNodeItem is
      ' created and initialized.
      OnItemCreated(eventArgs)

      ' The pathSeparator does not bind to any SiteMapNode, so
      ' do not call DataBind on the SiteMapNodeItem.
      item.Controls.Add(finalSeparator)

      ' Create a DropDownList and populate it with the children of the
      ' CurrentNode. There are no styles or templates that are applied
      ' to the DropDownList control. If OnSelectedIndexChanged is raised,
      ' the event handler redirects to the page selected.
      ' The CurrentNode has child nodes.
      Dim ddList As New DropDownList()
      ddList.AutoPostBack = True

      AddHandler ddList.SelectedIndexChanged, AddressOf Me.DropDownNavPathEventHandler

      ' Add a ListItem to the DropDownList for every node in the
      ' SiteMapNodes collection.
      Dim node As SiteMapNode
      For Each node In  childNodes
         ddList.Items.Add(New ListItem(node.Title, node.Url))
      Next node

      item.Controls.Add(ddList)
   End If
End Sub

Uwagi

Kontrolka SiteMapPath zarządza informacjami na temat nawigacji witryny jako kolekcją SiteMapNodeItem obiektów. SiteMapNodeItem obiekty reprezentują funkcjonalnie różne typy węzłów SiteMapNode . W związku z tym są one zarządzane przez kontrolkę SiteMapPath . Na poniższej liście opisano typy dostępnych węzłów:

  • Jeden węzeł reprezentujący aktualnie wyświetloną stronę.

  • Jeden węzeł, który jest głównym węzłem hierarchii nawigacji lokacji.

  • Zero lub więcej węzłów między górnym węzłem a bieżącym węzłem (węzłami nadrzędnymi).

  • Zero lub więcej węzłów reprezentujących separatory ścieżek nawigacji witryny.

Każdy węzeł jest powiązany z danymi bazowymi SiteMapNode, z wyjątkiem węzłów typu PathSeparator.

Dotyczy

Zobacz też