.NET TIPS [Silverlight 2]ページ内の特定の位置にジャンプするには?[C#、VB]デジタルアドバンテージ 一色 政彦2009/07/23 |
![]() |
SilverlightアプリケーションをHTMLページの一部として埋め込んでいる場合、そのHTMLページとやりとりを行いたい場面が出てくることが多い。例えば、Silverlightアプリケーション上でボタンが押されたときに、HTMLページ内の特定の位置へジャンプさせたいような場合だ。
次のSilverlightアプリケーションでは、Silverlightアプリケーション上のボタンをクリックすると、ページの後ろに記述している「◆ここにジャンプ◆」という位置に瞬時にスクロールする。
| ページ内の特定の位置にジャンプするSilverlightサンプル・アプリケーション |
このようにSilverlightアプリケーションからHTMLページの特定の位置にジャンプさせるには、まずはWebブラウザのWindowオブジェクトを取得する。このWindowオブジェクトは、Silverlight上ではHtmlWindowクラス(System.Windows.Browser名前空間)のオブジェクトとして表現され、HtmlPageクラス(System.Windows.Browser名前空間)の静的プロパティWindowで取得できる。
HtmlWindowオブジェクトには、HTMLページ内の特定の位置にジャンプさせるためのNavigateToBookmarkメソッドが用意されているので、これを次のようにして呼び出せばよい。
|
||
| ページ内の特定の位置にジャンプするサンプル・コード(上:C#、下:VB) |
上のサンプル・コードを見ると分かるが、NavigateToBookmarkメソッドでは、「ジャンプ先のアンカー・ポイント(=目印)の名前」を引数として指定する。戻り値はない。
そのアンカー・ポイントは、HTMLコードに次のように記述する。
<a name="アンカー・ポイント名"></a> |
もしくは、次のように記述。
|
|
| ※<div>タグだけでなく、任意のタグで使える。 |
例えば、次の1行の先頭には「<a name="abc"></a>」というアンカー・ポイントを設定している。そのため、先ほどのサンプルではこの位置にジャンプしたというわけだ。
NavigateToBookmarkメソッドによるアンカー・ポイントへのジャンプは、HTMLコードによる次の記述と同じ意味になる。
<a href="#abc">HTMLページ内の特定の位置にジャンプ</a>
Webブラウザのアドレス欄を確認してほしい。このHTMLコードもしくはSilverlightのNavigateToBookmarkメソッドのどちらでジャンプしても、HTMLページへのURLに続けて「#abc」というアンカー・ポイント名が付加されているはずだ。![]()
| カテゴリ:Silverlight 2 処理対象:ブラウザ 使用ライブラリ:HtmlWindowクラス(System.Windows.Browser名前空間) 使用ライブラリ:HtmlPageクラス(System.Windows.Browser名前空間) |
| 「.NET TIPS」 |
TechTargetジャパン
- 新人プログラマーのためのInsider.NETの歩き方 2012 (2012/5/22)
晴れて.NETプログラマーとなる新人が効率的に開発技術を習得するには? 大量にある記事群の中から新人が読むべきお勧めを厳選して紹介 - jQuery MobileでJavaScriptプログラミング (2012/5/17)
jQuery Mobileは手軽なだけでなく、JavaScriptのAPIも充実しており、独自機能の実装もできる。今回は「グローバル設定」と「イベント」を解説 - Windows上で開発するための開発環境構築入門 (2012/5/16)
Windowsを使ってチームで開発している? なのにサーバOSを設定・運用した経験がない? そうなら、今すぐ学ぼう - 「コントラクト」でアプリのサンドボックスを乗り越える! (2012/5/11)
Metroスタイル・アプリはサンドボックスの中で動作する。それを乗り越えてほかのアプリと連携する仕組み「コントラクト」を解説
|
|
キャリアアップ
スポンサーからのお知らせ
- - PR -
イベントカレンダー
- - PR -


