SiteMap for ASP.NET Web Forms

Similar documents
FileExplorer for ASP.NET Web Forms

Tabs for ASP.NET Web Forms

ComboBox for ASP.NET Web Forms

BinaryImage for ASP.NET Web Forms

Expander for ASP.NET Web Forms

Slider for ASP.NET Web Forms

ListView for ASP.NET Web Forms

ToolTip for ASP.NET Web Forms

ProgressBar for ASP.NET Web Forms

ComponentOne for ASP.NET Web Forms ユーザーガイド

Chart3D for WPF/Silverlight

C1Live

TreeView for ASP.NET Web Forms

目次 はじめに... 3 システムの必要条件... 3 サンプルアプリケーションの作成... 3 手順 手順 手順 手順 手順 手順 終わりに... 23

MVC4 Mobile Classic

Carousel for WPF/Silverlight

Accordion for ASP.NET Web Forms

Menu for ASP.NET Web Forms

ASP.NET 2.0 Provider Model 概要

Upload for ASP.NET Web Forms

目次 はじめに... 3 システムの必要条件... 4 ライセンス認証... 4 アクティベーション... 6 開発... 7 手順 1. アプリケーションの作成... 7 手順 2. データソースの作成と代入... 7 手順 3. テンプレートの作成 手順 4. レポートビューアの追加

Microsoft Word - VB.doc

ユーザ デバイス プロファイルの ファイル形式

Access 2010 の使用を開始する Access 2010 を開くと Backstage ビューが表示されます Backstage ビューには Access 2003 の * ファイル + メニューに表示されていたコマンドの多くが含まれています Backstage ビューでは 新規データベース

( 目次 ) 1. はじめに 開発環境の準備 仮想ディレクトリーの作成 ASP.NET のWeb アプリケーション開発環境準備 データベースの作成 データベースの追加 テーブルの作成

ComponentOne Studio for ASP.NET Web Forms ユーザーガイド

OTRS10 他社システムOTRS呼出利用手順書

DockControl for WPF/Silverlight

ゲートウェイのファイル形式

1. 画面拡大ショートカット ショートカットキーで作業効率 UP [Ctrl]+[+]: 拡大 [Ctrl]+[-]: 縮小 [Ctrl]+ 0 : デフォルトに戻す (100%) オンライン製品ヘルプ 2

産能大式フローチャート作成アドインマニュアル

印刷アプリケーションマニュアル

概要 ABAP 開発者が SAP システム内の SAP ソースまたは SAP ディクショナリーオブジェクトを変更しようとすると 2 つのアクセスキーを入力するよう求められます 1 特定のユーザーを開発者として登録する開発者キー このキーは一度だけ入力します 2 SAP ソースまたは SAP ディクシ

目次 概要... 2 フォームレイアウトデザイナー機能の設定... 3 設定したフォームレイアウトデザイナーの確認...14 その他スタイルの設定...15 フォームレイアウトデザイナーをエクスポート...17 フォームレイアウトデザイナーをインポート...18 インポート時の制限事項...19 リ

図 2 Excel スプレッドシートの世界 のウィンドウ 図 3 Visual Basic の世界 のウィンドウ 図 3 の VBA ウィンドウは 図 2 の Excel ウィンドウのメニューの ツール をクリックし 開か れるプルダウンメニューで マクロ /Visual Basic Editor

2) データの追加 一番下の行までスクロールしていき * のある行をクリックすると 新しいデータを入力できます その他の方法 Access では様々な使い方が用意されています その一例としては 右クリックを使用する方法もあります 画面の左端の部分にマウスを持っていくと が表示されます の上でクリック

スライド 0

マクロの実行許可設定をする方法 Excel2010 で 2010 でマクロを有効にする方法について説明します 参考 URL:

Section1_入力用テンプレートの作成

外周部だけ矩形配列

インフォメーション目次. 新着表示について (P0). インフォメーションの画面構成 (P0). インフォメーションを閲覧する (P0). インフォメーションを作成する (P05) 5. 本文に画像ファイルを貼り付ける (P07) 6. インフォメーションを変更 削除する (P08) 7. 公開前に

Userコントロール

電話機のファイル形式

UMLプロファイル 機能ガイド

Microsoft Word - HowToConvertIdwToDwg.doc

Microsoft Word 2003 から Word 2010 への移行 このガイドの内容 Microsoft Word 2010 の外観は Word 2003 と大きく異なるため Word 2003 のユーザーが少しでも早く慣れることができるようにこのガイドが作られました このガイドを読むと 新

APEX Spreadsheet ATP HOL JA - Read-Only

やってみようINFINITY-製品仕様書 品質評価表 メタデータ 編-

PDFViewer for WPF/Silverlight

Microsoft Word - プリンター登録_Windows XP Professional.doc

OneNote 2010 の使用を開始する 長い間 Microsoft OneNote を使用していたユーザーが OneNote 2010 に移行すると OneNote 2007 のコマンドやツールバーボタンがどこにあるのかわからなくなることがよくあります そのため トレーニングコース リボンガイド

更新履歴 変更履歴 版数 リリース日 更新内容 第 1 版 2017/5/15 第 1 版発行 第 2 版 2017/7/13 更新履歴 変更内容を追加 (2ページ) 編集の前に を追加(8 ページ ) ブロックエディタ スマートモード エディタモード の説明を追加 (10~12 ページ ) ブロッ

第 13 講データ管理 2 2 / 14 ページ 13-1 ファイルを開く 第 12 講で保存したデータベースファイル サークル名簿.accdb を開きましょう 1. Access を起動します 2. Microsoft Office Access - 作業の開始 が表示されていることを確認します

VB.NET解説

.NETプログラマー早期育成ドリル ~VB編 付録 文法早見表~

サイボウズ Office 10「リンク集」

Cisco ViewMail for Microsoft Outlook クイックスタートガイド (リリース 8.5 以降)

一般社団法人ビジネス機械・情報システム産業協会

データを TreeView コントロールで表示 VisualStudio2017 の Web サイトプロジェクトで bootstrap, 及び script フォルダの js ファイルが使用できるマスターページを親とする TestTreeView.aspx ページを作成します 下記の html コー

Input for ASP.NET WebForms

- 2 Copyright (C) All Rights Reserved.

McAfee SaaS Protection 統合ガイド Microsoft Office 365 と Exchange Online の保護

HTTP 404 への対処

2 / 25 複数ソフトの組み合わせ テキストファイルを Excel で開く テキスト形式 (.txt) で保存したファイルを Excel で利用しましょう 第 14 講で保存した west.txt を Excel で開きます 1. Excel を起動します 2. [Office ボタ

マイクロソフト IT アカデミー E ラーニングセントラル簡単マニュアル ( 管理者用 ) 2014 年 11 月

WebOTXマニュアル

Oracle Lite Tutorial

PowerPoint Presentation

サイボウズ Office「リンク集」

目次 はじめに プロファイルとモードについて キーボードのバックライトをカスタマイズする サポートに問い合わせる はじめに 1 Corsair ゲーミングのハードウェアとソフトウェアのインストール 2 ファームウェアのアップデート 3 プロファイルとモードについて 4 キーボードの

TREND CA Ver.3 手順書

DateTimeEditors for WPF/Silverlight

Transcription:

2018.03.08 更新 グレープシティ株式会社

目次 製品の概要 2 Help with ASP.NET Web Forms Edition 2 設計時のサポート 3-8 クイックスタート :SiteMap の作成とカスタマイズ 9-13 主な機能 14 データ連結 14-16 カスタム SiteMap プロバイダ 16-18 ツールチップの追加 18-20 レイアウトのカスタマイズ 20-22 ノードテンプレート 22 キーボードサポートの追加 22-24 C1SiteMapDataSourceの機能 25 新しい SiteMap の作成 25 既存の SiteMap の編集 25-26 サイトマップファイルの追加 26-27 1 Copyright GrapeCity Inc. All rights reserved.

製品の概要 SiteMap for ASP.NET Web Forms を使用すると ノードを作成したり すべての Web ページのリストを生成できるため Web アプリケーション内の移動がさらに容易になります SiteMap は最新のデータ連結技術を導入し Microsoft.Net Framework とシームレスに統合されています SiteMap は ノードレベルごとに異なるスタイルとレイアウトを作成でき ノードレベルごとにカスタムテンプレートを作成できます SiteMap パッケージには 次の 2 つのコントロールが含まれます 主要な機能 C1SiteMap: データ連結モードまたは非連結モードでサイトマップを作成するために使用します C1SiteMapDataSource:SiteMap コントロールをサイトマップファイルに連結するために使用します データ連結 :SiteMap をデータ連結モードおよび非連結モードで使用します また SiteMapDataSource を使用して SiteMap コントロールをサイトマップファイルまたは XML データに連結します レイアウト : リストとフローの2 種類のノードレイアウトを作成します テンプレート : レベルごとにカスタムテンプレートを設定します テーマ : 組み込みのテーマを使用したり 独自のテーマを作成することができます 深度 : レベルごとにノードの最大数を定義します ComponentOne Studio for ASP.NET Web Forms のヘルプ ComponentOne Studio for ASP.NET Webforms の各コントロールで共通したトピック アセンブリの追加 テーマの適用 クライアント側情報などについては ASP.NET Webforms ユーザーガイド を参照してください 2 Copyright GrapeCity Inc. All rights reserved.

設計時のサポート SiteMap は Visual Studio のプロパティグリッド メニュー およびデザイナを使用して設計時に設定できます 以下のセクションでは SiteMap の設計時機能を使用して コントロールを設定する方法について説明します [C1SiteMap のタスク ] メニュー トピックの内容 [C1SiteMap のタスク ] メ ニュー C1SiteMap デザイナ フォーム C1SiteMapLevelSettings コレクションエディタ データソースの選択 [ データソースの選択 ] ボックスのドロップダウン矢印をクリックすると 使用可能なデータソースのリストが開き 新しいデータソースを追加できます 新しいデータソースをプロジェクトに追加するには < 新しいデータソース > をクリックして データソース構成ウィザードを開きます 新しいデータソースをプロジェクトに追加する方法については データ連結 を参照してください ノードの編集 [ ノードの編集 ] をクリックすると さまざまなレベルにノードを追加および編集するための C1SiteMap デザイナフォームが開きます 詳細については C1SiteMap デザイナフォーム を参照してください DataBindings の編集 [ バインドの編集 ] をクリックすると SiteMap に追加するノードのデータ連結を管理するための Bindings コレクションエディタが開きます 3 Copyright GrapeCity Inc. All rights reserved.

テーマ [ テーマ ] ドロップダウンボックスで Theme プロパティを設定して コントロールの外観を定義済みのテーマのいずれかに変更できます 新しいテーマの作成 このリンクをクリックすると 新しいテーマフォームが開き 既存のテーマを使用して新しいテーマを作成したり テーマをインポートすることができます 4 Copyright GrapeCity Inc. All rights reserved.

Themeroller を使用した新しいテーマの作成方法については Themeroller for Visual Studio を参照してください CDN の使用 [CDN の使用 ] チェックボックスをオンにすると クライアントリソースが CDN からロードされます デフォルトでは このチェックボックスはオフです Bootstrap の使用 [Bootstrap の使用 ] チェックボックスをオンにすると コントロールに Bootstrap テーマが適用されます バージョン情報 [ バージョン情報 ] 項目をクリックすると [Studio for ASP.NET Web Forms のバージョン情報 ] ダイアログボックスが表示され ComponentOne Studio for ASP.NET Web Forms のバージョン番号とオンラインリソースが表示されます 先頭に戻る C1SiteMap デザイナフォーム このフォームでは SiteMap コントロールにノードを追加したり コントロール内の既存のノードを編集することができます 5 Copyright GrapeCity Inc. All rights reserved.

[ ファイル ] メニュー [ ファイル ] メニューでは 既存の XML ファイルからデータをロードしたり XML ファイルにデータを保存したり デザイナを終了することができます [ 編集 ] メニュー [ 編集 ] メニューでは ノードを追加したり 選択したノードに子ノードを追加することができます また 切り取り コピー 貼り付け 削除 名前の変更などの基本編集機能も実行できます 6 Copyright GrapeCity Inc. All rights reserved.

次の表で C1SiteMap デザイナフォームの各ボタンの機能について説明します アイコン ボタン 項目を上に移動 項目を下に移動 項目を左に移動 項目を右に移動 子項目の追加 説明 選択した項目を 1 ノード上に移動します 選択した項目を 1 ノード下に移動します 選択した項目を左に移動します 選択した項目を右に移動します 選択したノードに子項目を追加します 項目の挿入 切り取り / コピー / 貼り付け / 削除 選択したノードの兄弟ノードを追加します 選択したノードの切り取り コピー 貼り付け または削除を実行できます [ プレビュー ] タブ [ プレビュー ] タブでは ノードが出力にどのように表示されるかを確認できます 先頭に戻る C1SiteMapLevelSettings コレクションエディタ C1SiteMapLevelSetting コレクションエディタでは さまざまなレベルのノードの設定をカスタマイズできます 7 Copyright GrapeCity Inc. All rights reserved.

[ 追加 ] ボタンは 新しいレベル設定を追加します [ 削除 ] ボタンは 選択した設定を削除します 8 Copyright GrapeCity Inc. All rights reserved.

クイックスタート :SiteMap の作成とカスタマイズ ここでは 次の手順を実行して SiteMap コントロールを使用する簡単なアプリケーションを作成する方法を学びます 以下の手順は Visual Studio 2012 で作成されたアプリケーション用です 使用する Visual Studio のバージョンによっては 手順が多少異なる場合があります 手順 1/3: 3:Web フォームへの SiteMap の追加 トピックの内容 手順 1/3: 3:Web フォーム への SiteMap の追加 手順 2/3: 3:SiteMap への ノードの追加 1. Visual Studio で 新しい ASP.Net Web アプリケーションを作成し 新しい Web フォームを追加します 2. ツールボックスで SiteMap コントロールを見つけ Web フォームにドラッグします ツールボックスでコントロールが見つからない場合は 右クリックして [ 項目の選択 ] を選択し [ ツールボックス項目の選択 ] ダイアログボックスで SiteMap を見つけます 3. さらに サイトマップ内でリンクする Web ページごとに1つ 合計 3つの Web フォームを追加します 手順 2/3: 3:SiteMap へのノードの追加 手順 3/3: 3: 外観とレイアウ トのカスタマイズ 1. SiteMap コントロールを選択し スマートタグをクリックして [SiteMap のタスク ] メニューを開きます 2. [ ノードの編集 ] をクリックします これにより C1SiteMap デザイナフォームが開きます 3. [ 子項目の追加 ] ボタンを3 回クリックして 3つの子ノードを追加します 4. C1SiteMapNode2 をクリックし [ 項目を右に移動 ] ボタンをクリックします 9 Copyright GrapeCity Inc. All rights reserved.

5. C1SiteMapNode1 を選択します プロパティウィンドウの右側で NavigateUrl プロパティを Webform2.aspx に設定します 同様に C1SiteMapNode2 と C1SiteMapNode3 の NavigateUrl プロパティをそれぞれ Webform3.aspx と Webform4.aspx に設定します 6. [F5] キーを押してプロジェクトを実行します ソースビューの場合 次のマークアップを <cc1:c1sitemap></cc1:c1sitemap> タグ内に追加して SiteMap コントロールにいくつかのノードを追加します ASP.Net <Nodes> <cc1:c1sitemapnode runat="server" Text="C1SiteMapNode1" NavigateUrl="Web Form2.aspx"> <Nodes> <cc1:c1sitemapnode runat="server" NavigateUrl="Web Form3.aspx" Text="C1SiteMapNode2"> </cc1:c1sitemapnode> </Nodes> </cc1:c1sitemapnode> <cc1:c1sitemapnode runat="server" Text="C1SiteMapNode3" NavigateUrl="Web Form4.aspx"> </cc1:c1sitemapnode> </Nodes> コードの場合 次のコードを Page_Load イベントに追加して ノードを SiteMap コントロールに追加します C# でコードを書く場合 10 Copyright GrapeCity Inc. All rights reserved.

C# C1SiteMap1.Nodes.Add(new C1.Web.Wijmo.Controls.C1SiteMap.C1SiteMapNode()); C1SiteMap1.Nodes.Add(new C1.Web.Wijmo.Controls.C1SiteMap.C1SiteMapNode()); C1SiteMap1.Nodes[0].Nodes.Add(new C1.Web.Wijmo.Controls.C1SiteMap.C1SiteMapNode()); C1SiteMap1.Nodes[0].Text = "C1SiteMapNode1"; C1SiteMap1.Nodes[1].Text = "C1SiteMapNode1"; C1SiteMap1.Nodes[0].Nodes[0].Text = "C1SiteMapNode1Child1"; VB でコードを書く場合 VB C1SiteMap1.Nodes.Add(New C1.Web.Wijmo.Controls.C1SiteMap.C1SiteMapNode()) C1SiteMap1.Nodes.Add(New C1.Web.Wijmo.Controls.C1SiteMap.C1SiteMapNode()) C1SiteMap1.Nodes(0).Nodes.Add(New C1.Web.Wijmo.Controls.C1SiteMap.C1SiteMapNode()) C1SiteMap1.Nodes(0).Text = "C1SiteMapNode1" C1SiteMap1.Nodes(1).Text = "C1SiteMapNode1" C1SiteMap1.Nodes(0).Nodes(0).Text = "C1SiteMapNode1Child1" ここまでの成果 プロジェクトを実行すると C1SiteMapNode が次の図のように表示されます SiteMapNode1 と SiteMapNode3 はレベル 0 SiteMapNode2 はレベル 1 のノードです 手順 3/3: 3: 外観とレイアウトのカスタマイズ デザイナの場合 1. [SiteMap のタスク ] メニューを開き [ ノードの編集 ] を選択します 2. C1SiteMap デザイナフォームで C1SiteMap1 を選択し 右側で CssClass と ThemeSwatch を自由に設定します 3. Layout プロパティグループを展開し DefaultLevelSetting プロパティグループを展開し Layout を List に設定します メモ : プロジェクトに追加した画像を ImageUrl プロパティで選択することで 選択したレベルに画像を追加することもできます 4. ListLayout プロパティグループを展開し RepeatColumns を 2 に設定します さまざまなレベルのノードのレイアウトを変更する方法として C1SiteMapLevelSetting コレクションエディタを使用することもできます C1SiteMapLevelSetting コレクションエディタを使用してレイアウトを変更するには 次の手順に従います 1. SiteMap コントロールを右クリックし [ プロパティ ] を選択します 2. プロパティウィンドウで LevelSettings プロパティの横にある省略符ボタン (...) をクリックします これで C1SiteMapLevelSetting コレクションエディタが開きます 3. C1SiteMapLevelSetting コレクションエディタで [ 追加 ] ボタンをクリックして 新しいレベル設定を追加します 4. 右側で Level を1 Layout を Flow SeparatorText を, に設定します ソースビューの場合 11 Copyright GrapeCity Inc. All rights reserved.

次のマークアップを <cc1:c1sitemap></cc1:c1sitemap> タグ内に追加して レベル 0( デフォルトレベル ) ノードとレベル 1 ノードのレイアウトを変更します ASP.Net <LevelSettings> <cc1:c1sitemaplevelsetting Level="1" SeparatorText="," Layout="Flow"> </cc1:c1sitemaplevelsetting> </LevelSettings> <DefaultLevelSetting SeparatorText=" "> <ListLayout RepeatColumns="2" /> </DefaultLevelSetting> コードの場合 Page_Load イベントに次のコードを追加して DefaultLevel 設定を変更し 新しいレベル設定を追加します C# でコードを書く場合 C# // 新しい LevelSetting を追加します C1SiteMap1.LevelSettings.Add(new C1.Web.Wijmo.Controls.C1SiteMap.C1SiteMapLevelSetting()); // LevelSetting をカスタマイズします C1SiteMap1.LevelSettings[0].Level = 1; C1SiteMap1.LevelSettings[0].Layout = C1.Web.Wijmo.Controls.C1SiteMap.SiteMapLayoutType.Flow; C1SiteMap1.LevelSettings[0].SeparatorText = ","; // DefaultLevelSetting をカスタマイズします C1SiteMap1.DefaultLevelSetting.Level = 0; C1SiteMap1.DefaultLevelSetting.Layout = C1.Web.Wijmo.Controls.C1SiteMap.SiteMapLayoutType.List; C1SiteMap1.DefaultLevelSetting.ListLayout.RepeatColumns = 2; Visual Basic でコードを書く場合 VB ' 新しい LevelSetting を追加します C1SiteMap1.LevelSettings.Add(New C1.Web.Wijmo.Controls.C1SiteMap.C1SiteMapLevelSetting()) ' LevelSetting をカスタマイズします C1SiteMap1.LevelSettings(0).Level = 1 C1SiteMap1.LevelSettings(0).Layout = C1.Web.Wijmo.Controls.C1SiteMap.SiteMapLayoutType.Flow C1SiteMap1.LevelSettings(0).SeparatorText = "," ' DefaultLevelSetting をカスタマイズします C1SiteMap1.DefaultLevelSetting.Level = 0 C1SiteMap1.DefaultLevelSetting.Layout = C1.Web.Wijmo.Controls.C1SiteMap.SiteMapLayoutType.List C1SiteMap1.DefaultLevelSetting.ListLayout.RepeatColumns = 2 12 Copyright GrapeCity Inc. All rights reserved.

ここまでの成果 [F5] を押してプロジェクトを実行し すべてのレベル1ノードがセパレータを使用したフローフローレイアウトで表示され すべてのレベル0ノードが2つの列のリストとして表示されることを確認します 13 Copyright GrapeCity Inc. All rights reserved.

主な機能 データ連結 このトピックでは SiteMap を SiteMapDataSource XMLDataSource C1SiteMapDataSource の各コントロールに連結する方法を示します デザイナの場合 SiteMapDataSource コントロールを使用してコントロールにデータを設定するには 次の手順に従います 1. SiteMap コントロールを選択し スマートタグをクリックして [SiteMap のタスク ] メニューを開きます 2. [ データソースの選択 ] ドロップダウンを開き < 新しいデータソース > を選択します これにより ID フィールドに SiteMapDataSource1 が定義された状態でデータソース構成ウィザードが開きます 3. [ サイトマップ ] を選択し [OK] をクリックします これにより SiteMapDataSource コントロールが Web フォームに追加されます 4. SiteMapDataSource コントロールを右クリックし [ プロパティ ] をクリックします 5. プロパティウィンドウで SiteMapProvider の名前を追加します カスタム SiteMapProvider の作成方法については カスタム SiteMap プロバイダ を参照してください XML データを使用してコントロールにデータを設定するには 次の手順に従います 1. SiteMap コントロールを選択し スマートタグをクリックして [SiteMap のタスク ] メニューを開きます 2. [ データソースの選択 ] ドロップダウンを開き < 新しいデータソース > を選択します これにより データソース構成ウィザードが開きます [XML ファイル ] を選択します 14 Copyright GrapeCity Inc. All rights reserved.

3. 表示される [ データソースの構成 ] ダイアログボックスの [ データファイル ] から XML ファイルを選択し [OK] をクリックします DialogBoxDataSource コントロールを使用してコントロールにデータを設定するには 次の手順に従います 1. フォームに C1SiteMapDataSource コントロールを追加します 2. C1SiteMapDataSource コントロールを右クリックし [ プロパティ ] を選択します 3. プロパティウィンドウで SiteMapFile プロパティに.sitemap ファイルを追加します 4. [SiteMap のタスク ] メニューを開きます 5. [ データソースの選択 ] ドロップダウンを開き C1SiteMapDataSource1 を選択します ソースビューの場合 SiteMapDataSource コントロールを使用して SiteMap コントロールを連結するには 次の手順に従います 1. 次のマークアップを <form></form> タグ内に追加します ソースビュー <asp:sitemapdatasource ID="SiteMapDataSource1" runat="server" SiteMapProvider="C1CustomSiteMapProvider" /> 2. <cc1:c1sitemap> タグ内で DatasourceID を設定します ソースビュー <cc1:c1sitemap ID="C1SiteMap1" runat="server" DataSourceID="SiteMapDataSource1"> SiteMap コントロールを XML データに連結するには 次の手順に従います 1. 次のマークアップを <form></form> タグ内に追加します ソースビュー <asp:xmldatasource ID="XmlDataSource1" runat="server" 15 Copyright GrapeCity Inc. All rights reserved.

DataFile="~/App_Data/Menu_Structure.xml"></asp:XmlDataSource> 2. <cc1:c1sitemap> タグ内で DatasourceID を設定します ソースビュー <cc1:c1sitemap ID="C1SiteMap1" runat="server" DataSourceID="XmlDataSource1"> C1SiteMapDataSource コントロールを使用して SiteMap コントロールを連結するには 次の手順に従います 1. 次のマークアップを <form></form> タグ内に追加します ソースビュー <cc1:c1sitemapdatasource ID="C1SiteMapDataSource1" runat="server" SiteMapFile="~/web1.sitemap" /> 2. <cc1:c1sitemap> タグ内で DatasourceID を設定します ソースビュー <cc1:c1sitemap ID="C1SiteMap1" runat="server" DataSourceID="C1SiteMapDataSource1"> カスタム SiteMap プロバイダ カスタム SiteMap プロバイダを作成するには StaticSiteMapProvider クラスを継承し 要件を実装します 次の 2 つのメソッドをオーバーライドします BuildSiteMap():SiteMap を構築します GetRootNodeCore(): 構築したサイトマップのルートノードを返します SiteMap プロバイダの作成 次のコードは 単純なサイトマッププロバイダの作成方法を示します C# でコードを書く場合 C# public partial class C1CustomSiteMapProvider : StaticSiteMapProvider { private readonly object C1siteMapLock = new object(); private SiteMapNode C1SiteMapRoot; // BuildSiteMap() メソッドをオーバーライドします public override SiteMapNode BuildSiteMap() { // ロックを使用してスレッドセーフを提供します lock (C1siteMapLock) { if (C1SiteMapRoot!= null) { return C1SiteMapRoot; } base.clear(); CreateSiteMapRoot(); 16 Copyright GrapeCity Inc. All rights reserved.

} } CreateSiteMapNodes(); return C1SiteMapRoot; // GetRootNodeCore() メソッドをオーバーライドします protected override SiteMapNode GetRootNodeCore() { return BuildSiteMap(); } private void CreateSiteMapRoot() { C1SiteMapRoot = new SiteMapNode(this, "C1RootNode", "~/Default.aspx", "C1RootNode"); AddNode(C1SiteMapRoot); } private void CreateSiteMapNodes() { SiteMapNode node = null; for (int num = 1; num <= 3; num++) { node = new SiteMapNode(this, string.format("c1childnode{0}", num), string.format("~/webform{0}.aspx", num), string.format("c1childnode{0}", num)); AddNode(node, C1SiteMapRoot); } } } Visual Basic でコードを書く場合 VB Public Class C1CustomSiteMapProvider Inherits StaticSiteMapProvider Private ReadOnly C1siteMapLock As New Object() Private C1SiteMapRoot As SiteMapNode ' BuildSiteMap() メソッドをオーバーライドします Public Overrides Function BuildSiteMap() As SiteMapNode ' ロックを使用してスレッドセーフを提供します SyncLock C1siteMapLock If C1SiteMapRoot IsNot Nothing Then Return C1SiteMapRoot End If MyBase.Clear() CreateSiteMapRoot() CreateSiteMapNodes() Return C1SiteMapRoot End SyncLock 17 Copyright GrapeCity Inc. All rights reserved.

End Function ' GetRootNodeCore() メソッドをオーバーライドします Protected Overrides Function GetRootNodeCore() As SiteMapNode Return BuildSiteMap() End Function Private Sub CreateSiteMapRoot() C1SiteMapRoot = New SiteMapNode(Me, "C1RootNode", "~/Default.aspx", "C1RootNode") AddNode(C1SiteMapRoot) End Sub Private Sub CreateSiteMapNodes() Dim node As SiteMapNode = Nothing For num As Integer = 1 To 3 node = New SiteMapNode(Me, String.Format("C1ChildNode{0}", num), String.Format("~/WebForm{0}.aspx", num), String.Format("C1ChildNode{0}", num)) AddNode(node, C1SiteMapRoot) Next End Sub End Class SiteMap プロバイダの配布 カスタム SiteMap プロバイダは web.config ファイルに登録する必要があります <system.web></system.web> タグ内に次のマークアップを追加します マークアップ <sitemap defaultprovider="c1customsitemapprovider" enabled="true"> <providers> <clear/> <add name="c1customsitemapprovider" type="webapplication1.c1customsitemapprovider"/> </providers> </sitemap> ツールチップの追加 SiteMap では 各ノードにツールチップを追加できます デザイナの場合 1. SiteMap コントロールを右クリックし [ プロパティ ] を選択します 2. SiteMap コントロール全体の ToolTip プロパティにテキストを追加します 3. [SiteMap のタスク ] メニューを開き [ ノードの編集 ] を選択します これにより C1SiteMap デザイナフォームが開きます 任意のノードを選択し 各ノードの ToolTip プロパティを設定します ソースビューの場合 18 Copyright GrapeCity Inc. All rights reserved.

次のように <cc1:c1sitemap> タグ内の ToolTip プロパティを設定して コントロール全体にツールチップを追加します ASP.Net <cc1:c1sitemap ID="C1SiteMap1" runat="server" ToolTip="This is a SiteMap Control" ShowNodeLines="true" DataSourceID="C1SiteMapDataSource1"> 次のように <cc1:c1sitemapnode> タグ内の ToolTip プロパティを設定して 1 つのノードにツールチップを追加します ASP.Net <cc1:c1sitemapnode runat="server" Text="C1SiteMapNode1" ToolTip="This is a Node Tooltip"> コードの場合 コントロール全体にツールチップを追加するには Page_Load イベントに次のコードを追加します C# でコードを書く場合 C# C1.SiteMap1.ToolTip = "SiteMap Control"; Visual Basic でコードを書く場合 VB C1.SiteMap1.ToolTip = "SiteMap Control" 個々のノードにツールチップを追加するには Page_Load イベントに次のコードを追加します C# でコードを書く場合 C# C1SiteMap1.Nodes[0].ToolTip = "Parent1"; C1SiteMap1.Nodes[0].Nodes[0].ToolTip = "child1"; C1SiteMap1.Nodes[1].ToolTip = "parent2"; Visual Basic でコードを書く場合 VB C1SiteMap1.Nodes(0).ToolTip = "Parent1" C1SiteMap1.Nodes(0).Nodes(0).ToolTip = "child1" C1SiteMap1.Nodes(1).ToolTip = "parent2" ここまでの成果 プロジェクトを実行し SiteMap ノードの上にマウスを置きます ノード上にツールチップが表示されることがわかります 19 Copyright GrapeCity Inc. All rights reserved.

レイアウトのカスタマイズ SiteMap では ノードレベルごとに異なるレイアウトを追加できます 次の 2 種類のレイアウトがあります リスト : このレイアウトでは ノードを列に分けて表示できます ListLayout.RepeatColumns プロパティを変更して レイアウトに表示される列の数を定義できます フロー : このレイアウトでは ノードをセパレータで区切って1 行に表示できます SeparatorText プロパティを変更して セパレータを変更できます このトピックでは レベル 0 ノードとレベル 1 ノードのレイアウトを変更する方法を示します デザイナの場合 デザインビューでレベル 0( デフォルトレベル ) のレイアウトを変更するには 次の手順に従います 1. [SiteMap のタスク ] メニューを開き [ ノードの編集 ] を選択します これにより C1SiteMap デザイナフォームが開きます 2. C1SiteMap デザイナフォームで C1SiteMap1 を選択し DefaultLevelSetting.Layout を List に設定します 3. DefaultLevelSetting.ListLayout.RepeatColumns を2に設定します デザインビューでレベル 1 のレイアウトを変更するには 次の手順に従います 1. C1SiteMap デザイナフォームで LevelSettings プロパティの横にある省略符ボタン (...) をクリックして C1SiteMapLevelSettings コレクションエディタを開きます 2. [ 追加 ] ボタンをクリックして 新しいレベル設定を追加します 3. 右側で Level を1 Layout を Flow SeparatorText を, に設定します 4. [OK] をクリックして C1SiteMapLevelSettings コレクションエディタを閉じ 再度 [OK] をクリックして C1SiteMap デザイナフォームを閉じます レイアウトを Flow に設定したレベルは サイトマップの最後のレベルになります ソースビューの場合 ソースビューでレベル 0( デフォルトレベル ) のレイアウトを変更するには <cc1:c1sitemap></cc1:c1sitemap> タグ内に次のマークアップを追加します <DefaultLevelSetting SeparatorText=" " Level="0" Layout="List"> <ListLayout RepeatColumns="2" /> </DefaultLevelSetting> ソースビューでレベル 1 のレイアウトを変更するには <cc1:c1sitemap></cc1:c1sitemap> タグ内に次のマークアップを追加します <LevelSettings> <cc1:c1sitemaplevelsetting Layout="Flow" Level="1" SeparatorText=","> </cc1:c1sitemaplevelsetting> </LevelSettings> 20 Copyright GrapeCity Inc. All rights reserved.

コードの場合 コードでデフォルトレベルのレイアウトを変更するには Page_Load イベントに次のコードを追加します C# でコードを書く場合 C# C1SiteMap1.DefaultLevelSetting.SeparatorText = ","; C1SiteMap1.DefaultLevelSetting.Level = 0; C1SiteMap1.DefaultLevelSetting.Layout = C1.Web.Wijmo.Controls.C1SiteMap.SiteMapLayoutType.List; C1SiteMap1.DefaultLevelSetting.ListLayout.RepeatColumns = 2; VB でコードを書く場合 VB C1SiteMap1.DefaultLevelSetting.SeparatorText = "," C1SiteMap1.DefaultLevelSetting.Level = 0 C1SiteMap1.DefaultLevelSetting.Layout = C1.Web.Wijmo.Controls.C1SiteMap.SiteMapLayoutType.List C1SiteMap1.DefaultLevelSetting.ListLayout.RepeatColumns = 2 コードでレベル 1 のレイアウトを変更するには Page_Load イベントに次のコードを追加します C# でコードを書く場合 C# // 新しい LevelSetting を追加します C1SiteMap1.LevelSettings.Add(new C1.Web.Wijmo.Controls.C1SiteMap.C1SiteMapLevelSetting()); // LevelSetting をカスタマイズします C1SiteMap1.LevelSettings[0].Level = 1; C1SiteMap1.LevelSettings[0].Layout = C1.Web.Wijmo.Controls.C1SiteMap.SiteMapLayoutType.Flow; C1SiteMap1.LevelSettings[0].SeparatorText = ","; VB でコードを書く場合 VB ' 新しい LevelSetting を追加します C1SiteMap1.LevelSettings.Add(New C1.Web.Wijmo.Controls.C1SiteMap.C1SiteMapLevelSetting()) ' LevelSetting をカスタマイズします C1SiteMap1.LevelSettings(0).Level = 1 C1SiteMap1.LevelSettings(0).Layout = C1.Web.Wijmo.Controls.C1SiteMap.SiteMapLayoutType.Flow C1SiteMap1.LevelSettings(0).SeparatorText = "," ここまでの成果 プロジェクトを実行すると 次の図のように レベル0のノードは2 列のリストとして表示され レベル1のノードはカンマ, 区切 21 Copyright GrapeCity Inc. All rights reserved.

りの1 行 ( フロー ) に表示されます ノードテンプレート ノードテンプレートを追加することで 画像を追加したり ノードレベルのスタイルをカスタマイズすることができます ソースビューの場合 次のコードは <cc1:c1sitemaplevelsetting></cc1:c1sitemaplevelsetting タグ内でノードテンプレートを作成する方法を示します ソースビュー <LevelSettings> <cc1:c1sitemaplevelsetting Level="1"> <NodeTemplate> <asp:image ID="Image1" runat="server" Width="28px" Height="26px" ImageUrl="~/C1SiteMap/Images/Wijmo.png" /> <a href="#" class="template-text"> <%# Eval("description") %> </a> </NodeTemplate> </cc1:c1sitemaplevelsetting> <cc1:c1sitemaplevelsetting Level="2" Layout="Flow"> </cc1:c1sitemaplevelsetting> </LevelSettings> キーボードサポートの追加 AccessKey プロパティを変更して SiteMap コントロールにキーボードショートカットを追加できます 22 Copyright GrapeCity Inc. All rights reserved.

デザイナの場合 デザインビューでキーボードサポートを追加するには 次の手順に従います 1. [SiteMap のタスク ] メニューを開き [ ノードの編集 ] をクリックします これにより C1SiteMap デザイナフォームが開きます 2. C1SiteMap1 を選択し 右側で AccessKey プロパティを K などの値に設定します 3. 左で C1SiteMapNode1 を選択し 右側で AccessKey プロパティを N などの値に設定します ソースビューの場合 SiteMap コントロールにキーボードショートカットを追加するには <cc1:c1sitemap> タグ内で AccessKey プロパティを設定します ソースビュー <cc1:c1sitemap ID="C1SiteMap1" runat="server" AccessKey="K"> C1SiteMapNode にキーボードショートカットを追加するには <cc1:c1sitemapnode> タグ内で AccessKey プロパティを設定します ソースビュー <cc1:c1sitemapnode runat="server" Text="C1SiteMapNode1" AccessKey="N"> コードの場合 コントロール全体にキーボードショートカットを追加するには Page_Load イベントに次のコードを追加します C# でコードを書く場合 C# C1.SiteMap1.AccessKey= "k"; Visual Basic でコードを書く場合 VB C1.SiteMap1.AccessKey= "k" 個々のノードにキーボードショートカットを追加するには Page_Load イベントに次のコードを追加します C# でコードを書く場合 C# C1SiteMap1.Nodes[0].AccessKey= "a"; C1SiteMap1.Nodes[0].Nodes[0].AccessKey= "b"; C1SiteMap1.Nodes[1].AccessKey= "c"; Visual Basic でコードを書く場合 VB C1SiteMap1.Nodes(0).AccessKey= "a" C1SiteMap1.Nodes(0).Nodes(0).AccessKey= "b" C1SiteMap1.Nodes(1).AccessKey= "c" 23 Copyright GrapeCity Inc. All rights reserved.

ここまでの成果 プロジェクトを実行したら [Alt]+[K] キー (AccessKey) を押すと SiteMap コントロールが強調表示されます また [Alt] キーとノードの AccessKey を押すと 特定のノードが強調表示されます 24 Copyright GrapeCity Inc. All rights reserved.

C1SiteMapDataSource の機能 このトピックでは C1SiteMapDataSource の機能について説明します 新しい SiteMap の作成 C1SiteMapDataSource コントロールを使用して 新しい SiteMap を作成するには 次の手順に従います SiteMap コントロールを C1SiteMapDataSource コントロールに連結して 出力を表示します このトピックでは 4 つの Web フォームがプロジェクトに追加されており それぞれがサイトマップにリンクする Web ページを表していると仮定します デザイナの場合 1. SiteMap コントロールを選択し スマートタグをクリックして C1SiteMapDataSource のタスクメニュータスクメニューを開きます 2. [ ノードの編集 ] をクリックします これにより C1SiteMap デザイナフォームが開きます 3. [ 子項目の追加 ] ボタンを3 回クリックします 4. C1SiteMapNode2 をクリックし [ 項目を右に移動 ] ボタンをクリックします 5. C1SiteMapNode1 を選択します 右側で Url プロパティを Webform2.aspx に設定します 同様に C1SiteMapNode2 と C1SiteMapNode3 の Url プロパティをそれぞれ Webform3.aspx と Webform4.aspx に設定します web.sitemap という名前が付いた.sitemap ファイルが作成されて プロジェクトフォルダに保存されます ここまでの成果 SiteMap コントロールを C1SiteMapDataSource コントロールに連結し プロジェクトを実行すると サイトマップノードが次の図のように表示されます C1SiteMapNode1 と C1SiteMapNode3 はレベル 0 C1SiteMapNode2 はレベル 1 のノードです 既存の SiteMap の編集 既存のサイトマップノードを編集するには 次の手順に従います デザイナの場合 1. スマートタグをクリックして C1SiteMapDataSource のタスクメニュータスクメニューを開きます 2. [ 既存の SiteMap の編集 ] をクリックします これにより C1SiteMap デザイナフォームが開き フォームの左側に既存のすべてのノードが表示されます 25 Copyright GrapeCity Inc. All rights reserved.

3. 任意のノードを選択し [ 項目を上に移動 ] [ 項目を下に移動 ] [ 項目を左に移動 ] [ 項目を右に移動 ] の各ボタンをクリックして 選択したノードをそれぞれ上下左右に移動します 4. [ 切り取り ] [ コピー ] [ 貼り付け ] [ 削除 ] の各ボタンをクリックして 選択したノードを切り取り コピー 貼り付け または削除します 5. フォームの右側にあるプロパティウィンドウから Description Title および Url を変更することもできます サイトマップファイルの追加 サイトマップファイルを C1SiteMapDataSource コントロールに追加してデータを設定できます デザイナの場合.sitemap ファイルを C1SiteMapDataSource コントロールに追加するには 次の手順に従います 1. プロジェクトに.sitemap ファイルを追加します 2. C1SiteMapDataSource コントロールを右クリックし [ プロパティ ] を選択します 3. プロパティウィンドウで SiteMapFile プロパティの横にある省略符ボタン (...) をクリックします 4. [ ソースサイトマップファイルの選択 ] ダイアログボックスで.sitemap ファイルを選択し [OK] をクリックします 26 Copyright GrapeCity Inc. All rights reserved.

ソースビューの場合 ソースビューで.sitemap ファイルを追加するには <cc1:c1sitemapdatasource /> タグ内で SiteMapFile プロパティを設定します ソースビュー <cc1:c1sitemapdatasource ID="C1SiteMapDataSource1" runat="server" SiteMapFile="~/web1.sitemap" /> コードの場合.sitemap ファイルを C1SiteMapDataSourceControl に追加するには Page_Load イベントに次のコードを追加します C# でコードを書く場合 C# C1SiteMapDataSource1.SiteMapFile = "web1.sitemap"; Visual Basic でコードを書く場合 VB C1SiteMapDataSource1.SiteMapFile = "web1.sitemap" 27 Copyright GrapeCity Inc. All rights reserved.