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

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

ただいまの
回答率

90.47%

  • Monaca

    995questions

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

ons-navigatorでのページ遷移

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 872

Mori-Yukito

score 14

前提・実現したいこと

ons-navigatorでページを切り替えた後、ons-tabbarのons-tab要素を非表示にし、ons-toolbarにons-back-buttonを追加するコードを組みたいのですが、jQuery,angularJSは初心者なもので意図したように動作しません。御指南お願いします。
欲を言えば、タブの非表示、ons-back-buttonの追加はpage2.html内だけに留めておきたいです。

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

エラーメッセージ

該当のソースコード

index.html
<body>
<ons-navigator 
id="AniNavi">
<ons-page>
<ons-toolbar>
AniTimer</ons-toolbar>
<ons-tabbar>
<ons-tab page="home.html">
</ons-tab>
<ons-tab page="page1.html">
</ons-tab>
<ons-tab page="setteing.html">
</ons-tab>
</ons-tabbar>
</ons-page>
</ons-navigator>

page1.html
<body>
<ons-navigator id="sAniNavi" page="reference/aniList.html">
<ons-page>
<ons-list>
<ons-list-header></ons-list-header>
<ons-list-item class="springLiFont">

</ons-list-item>
<div style="text-align: center">
<ons-list-item tappable onclick="sAniNavi.pushPage('reference/page2.html')">

</ons-list-item>
</div>

<ons-list-header></ons-list-header>
<ons-list-item class="summerLiFont">

</ons-list-item>
<div type="text-align: center">
<ons-list-item tappable onclick="sAniNavi.pushPage('reference/page2.html')">

</ons-list-item>
</div>

<ons-list-header class="etcLiFont">

</ons-list-header>
<div type="text-align: center">
<ons-list-item tappable onclick="sAniNavi.pushPage('reference/page2.html')">

</ons-list-item>
</div>
</ons-list>
</ons-page>
</ons-navigator>
</body>

page2.html
<ons-page>
...
</ons-page>

試したこと

右も左も分かりません💦

補足情報(言語/FW/ツール等のバージョンなど)

より詳細な情報

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • akabee

    2017/05/31 21:06

    ページを切り替えた後に何か操作をしたいのであれば、該当の操作はreference/aniList.htmlとreference/sAniList.htmlで試行錯誤されているということで良いでしょうか?

    キャンセル

  • Mori-Yukito

    2017/06/01 07:46

    index.htmlの記載忘れでした。こちらの不手際でご迷惑をおかけし、申し訳ないです(._.)

    キャンセル

回答 2

checkベストアンサー

0

ひとまず、以下コードの一つ目のタブが想定されている動作になるかと思います。
OnsenUI V2 Angular1 Minimumテンプレート適用→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:; 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>
ons.ready(function() {
console.log("Onsen UI is ready!");
});

document.addEventListener('show', function(event) {
var page = event.target;
var titleElement = document.querySelector('#toolbar-title');

if (page.matches('#first-page')) {
titleElement.innerHTML = 'My app - Page 1';
} else if (page.matches('#second-page')) {
titleElement.innerHTML = 'My app - Page 2';
}
});
</script>
</head>
<body>

<ons-navigator id="mainNavigator" page="tabMain.html">

<ons-template id="tabMain.html"> 
<ons-page> 
<ons-toolbar> 
<div class="center" id="toolbar-title"></div> 
</ons-toolbar> 
<ons-tabbar position="bottom"> 
<ons-tab active label="検索" icon="fa-search" page="navigator1.html"> 
</ons-tab> 
<ons-tab label="マイページ" icon="fa-user" page="navigator2.html"> 
</ons-tab> 
<ons-tab label="メッセージ" icon="fa-envelope-o" page="navigator3.html"> 
</ons-tab> 
<ons-tab label="その他" icon="fa-ellipsis-h" page="navigator4.html"> 
</ons-tab> 
</ons-tabbar>
</ons-page>
</ons-template>

<ons-template id="navigator1.html"> 
<ons-navigator id="navigator1" page="tab1-1.html">
</ons-template>

<ons-template id="tab1-1.html">
  <ons-page>
  tab1-1
  <ons-button onclick="mainNavigator.pushPage('tab1-2.html')">push</ons-button>
  </ons-page>
</ons-template>

<ons-template id="tab1-2.html">
  <ons-page>
  <ons-toolbar> 
    <ons-back-button></ons-back-button>
    <div class="center" id="toolbar-title"></div> 
  </ons-toolbar> 
  tab1-2
  <ons-button onclick="mainNavigator.popPage()">pop</ons-button>
  </ons-page>
</ons-template>

<ons-template id="navigator2.html"> 
<ons-navigator id="navigator2" page="tab2-1.html">
</ons-template>

<ons-template id="tab2-1.html">
  <ons-page>
  tab2-1
  <ons-button onclick="navigator2.pushPage('tab2-2.html')">push</ons-button>
  </ons-page>
</ons-template>

<ons-template id="tab2-2.html">
  <ons-page>
  tab2-2
  <ons-button onclick="navigator2.popPage()">pop</ons-button>
  </ons-page>
</ons-template>

<ons-template id="navigator3.html"> 
<ons-navigator id="navigator3" page="tab3-1.html">
</ons-template>

<ons-template id="tab3-1.html">
  <ons-page>
  tab3-1
  <ons-button onclick="navigator3.pushPage('tab3-2.html')">push</ons-button>
  </ons-page>
</ons-template>

<ons-template id="tab3-2.html">
  <ons-page>
  tab3-2
  <ons-button onclick="navigator3.popPage()">pop</ons-button>
  </ons-page>
</ons-template>

<ons-template id="navigator4.html"> 
<ons-navigator id="navigator4" page="tab4-1.html">
</ons-template>

<ons-template id="tab4-1.html">
  <ons-page>
  tab4-1
  <ons-button onclick="navigator4.pushPage('tab4-2.html')">push</ons-button>
  </ons-page>
</ons-template>

<ons-template id="tab4-2.html">
  <ons-page>
  tab4-2
  <ons-button onclick="navigator4.popPage()">pop</ons-button>
  </ons-page>
</ons-template>

</body>
</html>

コードを見ていただくと分かると思いますが、そういうことがやりたい場合はタブ外側のons-navigatorとタブ内側のons-navigatorを明確に使い分ける必要があります。
Mori-Yukitoさんのコードであれば外側がAniNavi、内側がsAniNaviになります。

このあたりの画面構成を自由自在に設定するために、ons-tabとons-navigatorについて正確な理解が必要です。

onsenUIのリファレンスのほか、こちらこちらが参考になると思いますので読んでみてください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

文章から推測するしか無いですが、

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/onsen/2.2.6/css/onsenui.css" />
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/onsen/2.2.6/css/onsen-css-components.css" />
    <script src="https://cdnjs.cloudflare.com/ajax/libs/onsen/2.2.6/js/onsenui.js"></script>
<!--
    <script src="https://code.jquery.com/jquery-2.2.4.js"></script>
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.4/angular.min.js"></script>
-->
</head>

<body>
<ons-template id="tab1.html">
  <ons-page>
    <ons-toolbar>
      <div class="center">Tab 1</div>
    </ons-toolbar>

    <p style="text-align: center;">
      This is the first page.
    </p>
  </ons-page>
</ons-template>

<ons-template id="tab2.html">
  <ons-page>
    <ons-toolbar>
      <div class="center">Tab 2</div>
    </ons-toolbar>

    <p style="text-align: center;">
      This is the second page.
    </p>
  </ons-page>
</ons-template>

<ons-template id="page1.html">
  <ons-page id="page1">
    <ons-toolbar>
      <div class="center">Tab 0</div>
    </ons-toolbar>

    <ons-list>
      <ons-list-item tappable onclick="AppNavi.pushPage('page2.html')">Tap me</ons-list-item>
    </ons-list>
  </ons-page>
</ons-template>

<ons-template id="page2.html">
  <ons-page id="page2">
    <ons-toolbar>
      <div class="left"><ons-back-button>Back</ons-back-button></div>
      <div class="center"></div>
    </ons-toolbar>

    <p>This is the second page.</p>
  </ons-page>
</ons-template>

<ons-navigator id="AppNavi" page="tab.html">
</ons-navigator>

<ons-template id="tab.html">
<ons-tabbar>
  <ons-tab label="Tab 0" page="page1.html" active>
  </ons-tab>
  <ons-tab label="Tab 1" page="tab1.html">
  </ons-tab>
  <ons-tab label="Tab 2" page="tab2.html">
  </ons-tab>
</ons-tabbar>
</ons-template>

</body>
<script>
ons.ready(function() {
});
</script>
</html>

こういう挙動でいいのかしら。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/06/01 07:50

    index.htmlの記載忘れでした。こちらの不手際でご迷惑をおかけし、申し訳ないです(._.)

    キャンセル

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

  • ただいまの回答率 90.47%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    AngularJSとOnsenUIを使ったMonaca

    現在、Monacaでハイブリットアプリを制作しています。 【Onsen UI Tabbar】というテンプレートで制作を始めると、見た目はOnsenUIですが 画面遷移などはMV

  • 解決済

    AjaxからPHPへデータを送信

    前提・実現したいこと monacaとOnsenUIを使って同一ディレクトリから取り出したtextをチェックボックスに入れてチェックした値をサーバーに渡すというプログラムを作ってい

  • 解決済

    ons-navigatorの中でons-tabbarを使いたいが・・・

    前提・実現したいこと ここに質問したいことを詳細に書いてください (例)PHP(CakePHP)で●●なシステムを作っています。 ■■な機能を実装中に以下のエラーメッセージが

  • 解決済

    ons-tabの非表示

    前提・実現したいこと MonacaでOnsenUI v2を使ったアプリを製作していて、ons-tabを用いてページの切り替えを行っているのですが、ons-tab内のページでpus

  • 解決済

    ons-list-itemのページ遷移

    前提・実現したいこと MonacaでのWebアプリ開発についてです。 同階層のhtmlファイル間でのページ遷移を行いたいのですが、なかなか思うように動作しません。御指南お願いし

  • 解決済

    Onsen UI のons-tabとons-navigatorを組み合わせて使いたい

    以下のような画面遷移を実現したいと思っています。 タブで画面を大きくわけたい。 例えば、 タブ1(分類1)、タブ2(分類2)、タブ3(分類3) タブ1(分類1)の中で画面を

  • 解決済

    Onsen UIでのページ遷移ができません

    OnsenUIのナビゲーション型機能を作りたいのですが、page1.htmlからpage2.htmlへのページ遷移ができません。 初心の事だとは思いますが教えていただければ幸いです

  • 解決済

    Monacaでのタブ上のボタンによる画面遷移

     前提・実現したいこと monacaでハイブリッドアプリを開発しようと 試みております。 タブがありつつ タブ上のボタンを押下すると別ページに遷移するように実装をしたいのですが

同じタグがついた質問を見る

  • Monaca

    995questions

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