サンプルファイル 196.38 KB

 Silverlight 3の新機能のうち、多数のサブシステムからなる業務アプリケーションを作成するという観点では、標準的な画面遷移を提供するナビゲーションフレームワークが追加されたというのはうれしい変更点といえるでしょう。今回はナビゲーションフレームワークの概要とその仕組みについて触れていきます。

1 2 3 4 5 6 →

はじめに

 Silverlight 3では多くの新機能が追加されていますが、多数のサブシステムからなる業務アプリケーションを作成するという観点では、標準的な画面遷移を提供するナビゲーションフレームワークが追加されたというのはうれしい変更点といえるでしょう。

 今回はナビゲーションフレームワークの概要とその仕組みについて触れていきます。

Silverlightでの画面遷移

 Silverlight 2までの開発で多くの開発者を悩ませていた問題に、標準的な画面遷移(画面の切り替え)が存在しないという問題がありました。Silverlight 2まではWeb開発では当たり前だったハイパーリンクによる画面遷移や、現在の画面を閉じ新しい画面を開くといった画面遷移とは少し違った技を用いる必要がありました。

 Silverlight 2までは画面遷移の方法として大きく次の2つの方法がありました。

1. Webページ(HTML)のハイパーリンクやリダイレクトを呼び出す(図1)。
図1 HTMLと連携したページ遷移
図1 HTMLと連携したページ遷移

 この方法では、MainPage.xamlのボタンがクリックされたタイミングで、Silverlight側からMainPage.htmlにあるリンクやJavaScriptの関数を呼び出すことで画面遷移しています。

 画面の一部だけをSilverlightで作成し、ページの切り替えが必要な場合に便利です。

 ただし、HTMLの要素を利用していますので、Silverlight 3からの新機能であるブラウザ外でのSilverlightの実行機能では利用できません。また、移動先では再度Silverlightアプリケーションの読み込みが行われるため、アプリケーションの読み込みに時間がかかったり、Page間で状態を受け渡す場合にもASP.NETの状態管理やHTML-DOM連携などを利用した仕組みが必要となります。

 ブラウザ外でのSilverlightの実行機能に関しては、本連載の4回目を参照してください。

2. XAML要素を切り替える(図2)。

 こちらは1.のアプローチとよく似ていますが、画面遷移がSilverlight内で完結している点で異なります。

図2 XAML要素を切り替えてのページ遷移
図2 XAML要素を切り替えてのページ遷移

 各ページ(MainPage、Page1、Page2)はイベントが発生したタイミングでMainPage.xamlのコンテンツを切り替え、表示するページを切り替えることで画面遷移を行います。

 この方法で画面遷移を行うと、Silverlightのみで完結しているためスマートですし、画面間の状態管理もSilverlight内で行えばよいのでアプリケーションの構成もシンプルになります。

 しかし、Uriはどのページでも最初にロードされたMainPage.htmlであるため、たとえばPage2に直接移動したいとか、検索エンジンにクロールしてほしいとかいった場合にはほかにも仕組みを考える必要があるでしょう。またコンテンツの切り替えの部分は自前で作成する必要があるので少し難易度が高いかもしれません。

 このページ遷移の方法はSilverlight 2で大きく変わったコントロール』で詳しく触れられています。


プロフィール
WINGSプロジェクト かるあ (杉山 洋一) カルア(スギヤマ ヨウイチ)

WINGSプロジェクトについて>
有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2011年7月時点での登録メンバは36名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。


プロフィール
山田 祥寛 ヤマダ ヨシヒロ

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for ASP/ASP.NET。執筆コミュニティ「WINGSプロジェクト」代表。
主な著書に「入門シリーズ(サーバサイドAjax/XMLDB/PEAR/Smarty)」「独習シリーズ(ASP.NET/PHP)」「10日でおぼえる入門教室シリーズ(ASP.NET/PHP/Jakarta/JSP&サーブレット/XML)」「Pocket詳解辞典シリーズ(ASP.NET/PHP/Perl&CGI)」「今日からつかえるシリーズ(PHP/JSP&サーブレット/XML/ASP)」「書き込み式 SQLのドリル」他、著書多数


記事へのコメント・トラックバック機能は2011年6月に廃止させていただきました。記事に対する反響はTwitterやFacebook、ソーシャルブックマークサービスのコメントなどでぜひお寄せください。

スポンサーサイト