SiteMapNode.Clone Metoda

Definice

Vytvoří nový uzel, který je kopií aktuálního uzlu.

Přetížení

Clone()

Vytvoří nový uzel, který je kopií aktuálního uzlu.

Clone(Boolean)

Vytvoří novou kopii, která je kopií aktuálního uzlu, a volitelně naklonuje všechny nadřazené a nadřazené uzly aktuálního uzlu.

Clone()

Vytvoří nový uzel, který je kopií aktuálního uzlu.

public:
 virtual System::Web::SiteMapNode ^ Clone();
public virtual System.Web.SiteMapNode Clone ();
abstract member Clone : unit -> System.Web.SiteMapNode
override this.Clone : unit -> System.Web.SiteMapNode
Public Overridable Function Clone () As SiteMapNode

Návraty

Nový uzel, který je kopií aktuálního uzlu.

Poznámky

Zavolá metodu Clone s parametrem nastaveným na false. Vlastnosti zprostředkovatele, Title, Url, Descriptiona Key se zkopírují. Kolekce Roles a Attributes se zkopírují do nových kolekcí. Nadřazené a podřízené uzly se neklonují.

Viz také

Platí pro

Clone(Boolean)

Vytvoří novou kopii, která je kopií aktuálního uzlu, a volitelně naklonuje všechny nadřazené a nadřazené uzly aktuálního uzlu.

public:
 virtual System::Web::SiteMapNode ^ Clone(bool cloneParentNodes);
public virtual System.Web.SiteMapNode Clone (bool cloneParentNodes);
abstract member Clone : bool -> System.Web.SiteMapNode
override this.Clone : bool -> System.Web.SiteMapNode
Public Overridable Function Clone (cloneParentNodes As Boolean) As SiteMapNode

Parametry

cloneParentNodes
Boolean

trueklonovat všechny nadřazené a nadřazené uzly aktuálního uzlu; v opačném případě . false

Návraty

Nový uzel, který je kopií aktuálního uzlu.

Příklady

Následující příklad kódu ukazuje, jak volat metodu Clone k vytvoření duplicitního uzlu mapy webu z aktuálního uzlu. Metoda je zaregistrovaná ExpandForumPaths pro zpracování SiteMapResolve události. Používá metodu Clone k vytvoření pracovní kopie aktuálního uzlu mapy webu, úpravě atributů na základě dat přizpůsobení a vrácení pracovní kopie.

private void Page_Load(object sender, EventArgs e)
{
    // The ExpandForumPaths method is called to handle
    // the SiteMapResolve event.
    SiteMap.SiteMapResolve +=
      new SiteMapResolveEventHandler(this.ExpandForumPaths);
}

private SiteMapNode ExpandForumPaths(Object sender, SiteMapResolveEventArgs e)
{
    // The current node represents a Post page in a bulletin board forum.
    // Clone the current node and all of its relevant parents. This
    // returns a site map node that a developer can then
    // walk, modifying each node.Url property in turn.
    // Since the cloned nodes are separate from the underlying
    // site navigation structure, the fixups that are made do not
    // effect the overall site navigation structure.
    SiteMapNode currentNode = SiteMap.CurrentNode.Clone(true);
    SiteMapNode tempNode = currentNode;

    // Obtain the recent IDs.
    int forumGroupID = GetMostRecentForumGroupID();
    int forumID = GetMostRecentForumID(forumGroupID);
    int postID = GetMostRecentPostID(forumID);

    // The current node, and its parents, can be modified to include
    // dynamic querystring information relevant to the currently
    // executing request.
    if (0 != postID)
    {
        tempNode.Url = tempNode.Url + "?PostID=" + postID.ToString();
    }

    if ((null != (tempNode = tempNode.ParentNode)) &&
        (0 != forumID))
    {
        tempNode.Url = tempNode.Url + "?ForumID=" + forumID.ToString();
    }

    if ((null != (tempNode = tempNode.ParentNode)) &&
        (0 != forumGroupID))
    {
        tempNode.Url = tempNode.Url + "?ForumGroupID=" + forumGroupID.ToString();
    }

    return currentNode;
}
Private Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs)

    ' The ExpandForumPaths method is called to handle
    ' the SiteMapResolve event.
    AddHandler SiteMap.SiteMapResolve, AddressOf Me.ExpandForumPaths

End Sub

Private Function ExpandForumPaths(ByVal sender As Object, ByVal e As SiteMapResolveEventArgs) As SiteMapNode
    ' The current node represents a Post page in a bulletin board forum.
    ' Clone the current node and all of its relevant parents. This
    ' returns a site map node that a developer can then
    ' walk, modifying each node.Url property in turn.
    ' Since the cloned nodes are separate from the underlying
    ' site navigation structure, the fixups that are made do not
    ' effect the overall site navigation structure.
    Dim currentNode As SiteMapNode = SiteMap.CurrentNode.Clone(True)
    Dim tempNode As SiteMapNode = currentNode

    ' Obtain the recent IDs.
    Dim forumGroupID As Integer = GetMostRecentForumGroupID()
    Dim forumID As Integer = GetMostRecentForumID(forumGroupID)
    Dim postID As Integer = GetMostRecentPostID(forumID)

    ' The current node, and its parents, can be modified to include
    ' dynamic querystring information relevant to the currently
    ' executing request.
    If Not (0 = postID) Then
        tempNode.Url = tempNode.Url & "?PostID=" & postID.ToString()
    End If

    tempNode = tempNode.ParentNode
    If Not (0 = forumID) And Not (tempNode Is Nothing) Then
        tempNode.Url = tempNode.Url & "?ForumID=" & forumID.ToString()
    End If

    tempNode = tempNode.ParentNode
    If Not (0 = ForumGroupID) And Not (tempNode Is Nothing) Then
        tempNode.Url = tempNode.Url & "?ForumGroupID=" & forumGroupID.ToString()
    End If

    Return currentNode

End Function

Poznámky

cloneParentNodes Pokud je trueparametr , Clone metoda rekurzivně klonuje všechny uzly s přímým nadřazeným uzlem a přidruží je k aktuálnímu klonovanému uzlu. Podřízené uzly se neklonují.

Kolekce Roles a Attributes se použijí na nové kolekce.

Viz také

Platí pro