jQueryMobile

同じHTML文書に複数ページを作成してみる

jQueryMobileでは、同じHTML文書内に複数ページを作成することができます。手順は以下の通りです。

1.data-role="page"を付したHTMLタグを<body>内に必要なページの分だけ追加する。
2.1で追加したタグに、書くページを判別するためのid属性を付す
3.それぞれのページで遷移(表示)するためのリンクを作成する。

data-role="page"を付したHTMLタグを<body>内に必要なページの分だけ追加する。

ページを作成するには、data-role="page"を追加したタグでコンテンツを囲みます。この囲んだものをbodyタグの中に複数書けば、それだけで複数ページを作成することができます。

追加したタグに、書くページを判別するためのid属性を付す

data-role="page"を付したタグで複数ページを作成しても、1ページ目しか表示されません。他のページを表示するには、それぞれページへ遷移するリンクを設定します。その遷移先のリンクを示すのがid属性です。id属性は、HTML文書内のどのタグにも設定できますが、同じ文書内で重複した値を設定できません。

それぞれのページで遷移(表示)するためのリンクを作成する。

ページを囲むタグにid属性を設定したら、それぞれのページに遷移するリンクを作成します。今回のサンプルコードではaタグを使っています。

サンプルコードの実行結果はこちら

各ページのタイトル

同じHTML文書内に複数ページを作成したとき、data-role="page"が追加された最初のタグが1ページとして扱われます。このページのデフォルトのタイトルはtitleタグに囲まれた文字列です。
2ページ以降のデフォルトのタイトルは、ヘッダ(data-role="header"を追加したタグ)内の<h1>~<h6>で囲まれた文字列です。これは、それぞれのページが画面に表示されるときにtitleタグ内の文字列を変更することで表現しています。これを変更するとブラウザ画面に表示されるHTML文書のタイトルも変更されます。

別のHTML文書へのリンク

別のHTML文書に遷移するリンクを作成するときは、リンク先にその文書を示すURLを設定します。リンク先のHTML文書の読み込みはajax(ページの部分的な書き換え)により実行されます。

-jQueryMobile
-