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

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

ただいまの
回答率

90.09%

OnsenUI tabberの引継ぎ

解決済

回答 1

投稿 編集

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

sato1108

score 12

 前提・実現したいこと

<ons-tabbar>を使用してタブを遷移させているのですが、その中のボタンから.pushPageで遷移した際に<ons-tabbar>もそのまま引き継ぎたいのですがやり方がわかりません。
http://www.sky-limit-future.com/entry/2017/08/26/011314
上記のURLの方法で引き継げますと書かれていますが、あまりわからずに困っています。
URLの方法でなくても構いませんのでもしご存じの方いらっしゃいましたら助言頂けると幸いです。

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

エラーメッセージ

 該当のソースコード

     <script>
        $scope.newInfoSetting = function (){
            //遷移先で必要な情報を取得し、遷移した際に表示するjsvascript        
            myNavigator.pushPage('infotoolnavigator.html');
        }
     </script>

<body ng-controller="AppController as app">

    <ons-navigator var="myNavigator" page="login.html">
        //最初のページ遷移先
        <ons-template id="login.html">
            <ons-page>
                <div id="topBack">
                    <img src="default.png" width="100%" onclick="myNavigator.pushPage('startup.html')">
                </div>
            </ons-page>
        </ons-template>

//ログイン完了後遷移先
<ons-template id="mainmenu.html">    
<ons-page>
    <!--ツールバー設定-->
    <ons-toolbar>
       <div class="left"> </div>
       <div class="center" style="text-align: center;">{{app.title}}</div>
       <div class="right">
          <ons-icon icon="cog" size="20px" ng-click="newInfoSetting()"></ons-icon>
        </div>

    <!--    タブバー関連    -->
    <ons-tabbar position="bottom">
        <!--画面1-->
        <ons-tab page="infonavigator.html" label="***" icon="ion-home" active></ons-tab>
        <!--画面2-->
        <ons-tab page="second/page2.html" label="***" icon="square"></ons-tab>
        <!--画面3-->
        <ons-tab page="third/page3.html" label="****" icon="square"></ons-tab>
        <!--画面4-->
        <ons-tab page="fourth/page4.html" label="****" icon="square"></ons-tab>
        <!--画面5-->
        <ons-tab page="fifth/page5.html" label="***" icon="square"></ons-tab>
    </ons-tabbar>
</ons-page>
</ons-template>

<ons-template id="login.html">
    <ons-page>
        <div  id="topBack">
            <img src="default.png" width="100%" onclick="myNavigator.pushPage('login/startup.html'">
        </div>
    </ons-page>
</ons-template>

<ons-template id="infotoolnavigator.html">
  <ons-navigator var="infotoolnavigator" page="new_info/setting.html">
</ons-template>

<ons-template id="infonavigator.html">
  <ons-navigator var="infonavigator" page="new_info/list.html">
</ons-template>



</body>
//setting.html(ファイル名)
page1-1
<ons-page id="setting.html">
  内容記載
  <ons-button onclick="myNavigator.pushPage('new_info/setting2.html')">push</ons-button>
</ons-page>

 試したこと

ここに問題に対して試したことを記載してください。

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

ここにより詳細な情報を記載してください。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

0

タブを引き継ぐとは、こちらのような動作のことでしょうか?
回答の中にあるコードをMonacaにペーストすれば動作しますので試してみてください。

上記で間違いなければ、同様の質問はこちらこちらにもあります。
ある程度ons-navigatorについて解説していますので内容を確認してみてください。

【追記コード】
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="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>

tab1-1.html

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

tab1-2.html

  <ons-page>
  tab1-2
  <ons-button onclick="navigator1.popPage()">pop</ons-button>
  </ons-page>

【追記2】

//setting.html(ファイル名)
page1-1
<ons-page id="setting.html">
  内容記載
  <ons-button onclick="infonavigator.pushPage('new_info/setting2.html')">push</ons-button>
</ons-page>

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/05/25 10:29

    ありがとうございます。うまくいきました!
    おっしゃる通りでした。。。navigatorの引継ぎがうまくできていなかった為でした。ありがとうございます。説明が下手ですみません。

    キャンセル

  • 2018/05/25 10:42

    最初は手探りかもしれませんが、頑張ってください。
    もしプログラミング初心者であれば、プログラㇺの一行一行には必ず意味がありますので、
    ひとつひとつの理解を先送りにせずすべてを理解していくほうが、最終的なスキルは高くなります。

    キャンセル

  • 2018/05/25 11:58

    その通りですね。
    肝に銘じてやっていこうと思います。
    ありがとうございます。

    キャンセル

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

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