質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Onsen UI

HTML5で記述されたモバイルアプリの高速化、およびネイティブアプリライクなUIが作れるフレームワーク。 様々なJavaScriptフレームワークと併せて使用することができます。スマートフォン向けアプリ、Webサイトに必要なアニメーション、UI/UXを実装することが可能になります。

Monaca

「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

Q&A

0回答

1551閲覧

monacaのアプリ開発でtabbarとnavigatorを併用する際のファイル分けについて

penmark

総合スコア6

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Onsen UI

HTML5で記述されたモバイルアプリの高速化、およびネイティブアプリライクなUIが作れるフレームワーク。 様々なJavaScriptフレームワークと併せて使用することができます。スマートフォン向けアプリ、Webサイトに必要なアニメーション、UI/UXを実装することが可能になります。

Monaca

「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

0グッド

0クリップ

投稿2017/12/16 07:51

編集2017/12/17 08:40

###前提・実現したいこと
MonacaでOnsenUI v2にて、ons-tabとons-navigatorを併用したページ遷移を、ファイル分けで実装したい。

こちらの記事(https://teratail.com/questions/74290)を参考に、「indexにons-navigatorを設定→ons-navigatorでons-tabのページを呼び出し→ons-tab内の1ページからpushPageを行うとons-tabごとページが切り替わる」という機能を実装しました。

実際に作成するアプリは複数の機能を実装したもっと複雑なものになるため、完成した雛形を使いやすくしようと思い、ons-page毎にhtmlファイルを作りファイル分けを行いました。

###発生している問題・エラーメッセージ

ons-page毎にファイル分けしたところ、pushPageを行ってもページ遷移が起きなくなってしまいました。

ファイル分けを行う際、ons-templateは削除して、ons-page単位でhtmlファイルを作成したのですが、なぜ動かなくなってしまったのでしょうか?

アドバイスを頂けると幸いです。

###該当のソースコード

**//index.html** <!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> <meta http-equiv="Content-Security-Policy" content="default-src * data: gap: https://ssl.gstatic.com; style-src * 'unsafe-inline'; script-src * 'unsafe-inline' 'unsafe-eval'"> <script src="components/loader.js"></script> <script src="lib/onsenui/js/onsenui.min.js"></script> <link rel="stylesheet" href="components/loader.css"> <link rel="stylesheet" href="lib/onsenui/css/onsenui.css"> <link rel="stylesheet" href="lib/onsenui/css/onsen-css-components.css"> <link rel="stylesheet" href="css/style.css"> <script> // Page init event document.addEventListener('init', function(event) { var page = event.target; if (page.matches('#first-page')) { page.querySelector('#push-button').onclick = function() { document.querySelector('#navigator').pushPage('page1-1-1.html'); }; } else if (page.matches('#second-page')) { page.querySelector('#pop-button').onclick = function() { document.querySelector('#navigator').popPage(); }; } }); </script> </head> <body> <ons-page> <ons-navigator id="navigator" page="top.html"></ons-navigator> </ons-page> </body> </html> **//top.html** <ons-page> <ons-tabbar position="auto"> <ons-tab label="Tab 1" page="tab1.html" active> </ons-tab> <ons-tab label="Tab 2" page="tab2.html"> </ons-tab> </ons-tabbar> </ons-page> **//tab1.html** <ons-page> <ons-toolbar> <div class="center" id="toolbar-title">tab1</div> </ons-toolbar> <ons-tabbar position="top"> <ons-tab label="Tab 1-1" page="tab1-1.html" active> </ons-tab> <ons-tab label="Tab 1-2" page="tab1-2.html"> </ons-tab> </ons-tabbar> </ons-page> **//tab2.html** <ons-page> <ons-toolbar> <div class="center">tab2</div> </ons-toolbar> </ons-page> **//tab1-1.html** <ons-page id="first-page"> <div class="content" style="text-align: center"> <p>This is the first page.</p> <ons-button id="push-button">Push page</ons-button> </div>A </ons-page> **//tab1-2.html** <ons-page> </ons-page> **//tab1-1-1.html** <ons-page id="second-page"> <ons-toolbar> <div class="left"><ons-back-button>tab 1-1</ons-back-button></div> <div class="center">tab 1-1-1</div> </ons-toolbar> <div class="content" style="text-align: center"> <p>This is the second page.</p> <ons-button id="pop-button">Pop page</ons-button> </div> </ons-page>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問