SiteMapNodeCollection.Add メソッド
アセンブリ: System.Web (system.web.dll 内)

Dim instance As SiteMapNodeCollection Dim value As SiteMapNode Dim returnValue As Integer returnValue = instance.Add(value)
戻り値
SiteMapNode が挿入された InnerList のインデックス。


SiteMapNode オブジェクトを読み取り専用または固定サイズの SiteMapNodeCollection コレクションに追加することはできません。IsReadOnly プロパティをチェックすることにより、SiteMapNodeCollection が読み取り専用であるかどうかをテストできます。

このセクションには、2 つのコード例が含まれています。新しい SiteMapNodeCollection コレクションを作成して、それに要素を追加する方法を最初のコード例に示します。要素をカスタム サイト マップ プロバイダに追加する方法を 2 番目のコード例に示します。
SiteMapNodeCollection コンストラクタを使用して新しい SiteMapNodeCollection を作成し、Add メソッドを使用して要素をそれに追加する方法を次のコード例に示します。
' The LoadSiteMapData() Function loads site navigation ' data from persistent storage into a DataTable. Dim siteMapData As DataTable siteMapData = LoadSiteMapData() ' Create a SiteMapNodeCollection. Dim nodes As New SiteMapNodeCollection() ' Create a SiteMapNode and add it to the collection. Dim tempNode As SiteMapNode Dim row As DataRow Dim index As Integer index = 0 While (index < siteMapData.Rows.Count) row = siteMapData.Rows(index) ' Create a node based on the data in the DataRow. tempNode = New SiteMapNode(SiteMap.Provider, row("Key").ToString(), row("Url").ToString()) ' Add the node to the collection. nodes.Add(tempNode) index = index + 1 End While
// The LoadSiteMapData() method loads site navigation // data from persistent storage into a DataTable. DataTable siteMap = LoadSiteMapData(); // Create a SiteMapNodeCollection. SiteMapNodeCollection nodes = new SiteMapNodeCollection(); // Create a SiteMapNode and add it to the collection. SiteMapNode tempNode; DataRow row; int index = 0; while (index < siteMap.Rows.Count) { row = siteMap.Rows[index]; // Create a node based on the data in the DataRow. tempNode = new SiteMapNode(SiteMap.Provider, row["Key"].ToString(), row["Url"].ToString()); // Add the node to the collection. nodes.Add(tempNode); ++index; }
カスタム サイト マップ プロバイダの実装方法、および SiteMapNodeCollection コンストラクタを使用して新しい SiteMapNodeCollection を作成し、Add メソッドを使用して要素を SiteMapNodeCollection に追加する方法を次のコード例に示します。
このコード例は、SiteMapProvider クラスのトピックで取り上げている、コード例の一部分です。
' Implement the GetChildNodes method. Public Overrides Function GetChildNodes(ByVal node As SiteMapNode) As SiteMapNodeCollection Dim children As New SiteMapNodeCollection() ' Iterate through the ArrayList and find all nodes that have the specified node as a parent. SyncLock Me Dim i As Integer For i = 0 To childParentRelationship.Count - 1 Dim de As DictionaryEntry = CType(childParentRelationship(i), DictionaryEntry) Dim nodeUrl As String = CType(de.Key, String) Dim parent As SiteMapNode = GetNode(childParentRelationship, nodeUrl) If Not (parent Is Nothing) AndAlso node.Url = parent.Url Then ' The SiteMapNode with the Url that corresponds to nodeUrl ' is a child of the specified node. Get the SiteMapNode for ' the nodeUrl. Dim child As SiteMapNode = FindSiteMapNode(nodeUrl) If Not (child Is Nothing) Then children.Add(CType(child, SiteMapNode)) Else Throw New Exception("ArrayLists not in sync.") End If End If Next i End SyncLock Return children End Function 'GetChildNodes Protected Overrides Function GetRootNodeCore() As SiteMapNode Return RootNode End Function ' GetRootNodeCore() ' Implement the GetParentNode method. Public Overrides Function GetParentNode(ByVal node As SiteMapNode) As SiteMapNode ' Check the childParentRelationship table and find the parent of the current node. ' If there is no parent, the current node is the RootNode. Dim parent As SiteMapNode = Nothing SyncLock Me ' Get the Value of the node in childParentRelationship parent = GetNode(childParentRelationship, node.Url) End SyncLock Return parent End Function 'GetParentNode
// Implement the GetChildNodes method. public override SiteMapNodeCollection GetChildNodes(SiteMapNode node) { SiteMapNodeCollection children = new SiteMapNodeCollection(); // Iterate through the ArrayList and find all nodes that have the specified node as a parent. lock (this) { for (int i = 0; i < childParentRelationship.Count; i++) { string nodeUrl = ((DictionaryEntry)childParentRelationship[i]).Key as string; SiteMapNode parent = GetNode(childParentRelationship, nodeUrl); if (parent != null && node.Url == parent.Url) { // The SiteMapNode with the Url that corresponds to nodeUrl // is a child of the specified node. Get the SiteMapNode for // the nodeUrl. SiteMapNode child = FindSiteMapNode(nodeUrl); if (child != null) { children.Add(child as SiteMapNode); } else { throw new Exception("ArrayLists not in sync."); } } } } return children; } protected override SiteMapNode GetRootNodeCore() { return RootNode; } // Implement the GetParentNode method. public override SiteMapNode GetParentNode(SiteMapNode node) { // Check the childParentRelationship table and find the parent of the current node. // If there is no parent, the current node is the RootNode. SiteMapNode parent = null; lock (this) { // Get the Value of the node in childParentRelationship parent = GetNode(childParentRelationship, node.Url); } return parent; }

Windows 98, Windows 2000 SP4, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


- SiteMapNodeCollection.Add メソッドのページへのリンク