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

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

ただいまの
回答率

90.48%

  • HTML5

    4193questions

    HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

  • CSS3

    2145questions

    CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

  • Monaca

    997questions

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

  • AngularJS

    571questions

    AngularJSはオープンソースのJavaScriptフレームワークです。ブラウザ上で動作するウェブアプリケーションの開発にMVCアーキテクチャを取り入れることを目的としています。

  • Onsen UI

    327questions

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

OnsenUI tabberの引継ぎ

解決済

回答 1

投稿 編集

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

sato1108

score 6

 前提・実現したいこと

<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/23 12:40

    ありがとうございます。
    htmlを載せたのですが、ツールバーの詳細をクリックするとツールバーとタブバーを引き継いで***.htmlページに飛びたいのですが、ページ自体は全体のページ数が多く、indexに全て書きたくなかったので、別ページにあります。
    こういった場合は引継ぎは難しいでしょうか。

    キャンセル

  • 2018/05/23 22:33

    問題ないですよ。
    ****.htmlは単一のページですか?それともタブごとに異なる詳細ページですか?
    どちらであってもリンク先のページのコードを例にすることで実現できると思います。
    イメージと違う場合は、どのように違うか教えて頂ければDaiki1108さんのコードで実現できるかどうか考えてみます。

    キャンセル

  • 2018/05/24 09:13 編集

    ツールバーのソースをのせていませんが、タブごとに違うツールバーを表示させて、タブごとに異なる詳細ページへ遷移させるといった形です。それぞれのタブの詳細ページからまた2,3ページ遷移させますが、全てにmainmenu.htmlのタブを共通で持たせたいと思っています。
    上記のソースだと、
    <ons-navigator var="myNavigator" page="login.html"></ons-navigator>
    で一番初めにタブを持たないログインページへ飛んで、ログインが完了したら
    myNavigator.resetToPage('mainmenu.html');(ソースに記載はないですが)
    でmainmenu.htmlに飛んできてそこから全てでタブを持たせたいと思っています。
    飛ばす為だけに定義している<ons-navigator var="myNavigator" page="login.html"></ons-navigator>の書き方がそもそもいけないのでしょうか?

    キャンセル

  • 2018/05/24 11:25

    何も問題はないですよ。私の認識通りだと思います。
    リンク先のコードで実現できますので試してみてください。
    試してみた結果、イメージと違いましたか?

    キャンセル

  • 2018/05/24 12:04

    上記のリンクの様な動きでイメージ通りです。
    しかし、自分の今作成しているソースと違ったのでソースコードの内容を修正させて頂きました。
    別ページにあるという意味は別ファイルにあるという意味です。別ファイルの<ons-page>の中に飛ぶという感じです。そこにタブを引継ぎたいのですが、いまいちわからなくて。。。伝えるのが下手ですみません。

    キャンセル

  • 2018/05/24 13:07

    リンク先のコードを一部修正して、「別ファイルのons-pageの中に飛ぶ」ということを実現してみましたがこういうことですか?
    tab1-1.htmlとtab1-2.htmlを参照してください。
    恐らくons-templateが理解できていないと思います。ons-templateはそのタグで囲まれている範囲のコードを疑似的なhtmlとして扱うようにするという機能です。ons-template内に記載されているコードをそのまま別ファイル化すれば、ons-templateで記載されていたときと同様に動作します。

    ただしポイントはそこではなくてons-navigatorを複数定義しているところです。ons-tabが指すpageをons-navigatorが定義されているhtmlとし、それを起点として画面遷移を行えばons-tab毎に別々の画面遷移を行うことができます。

    キャンセル

  • 2018/05/24 14:33

    そういうことで概ね合っているのですが、ons-template自体はやはりindexに記載するしかないでしょうか。

    自分のソースに当てはめて試したのですが、どうにも引き継げません。新しく記載したソースにはツールバーからの遷移とtabの内容からの遷移で引き継げるか試した例を記載します。どこか悪いでしょうか。

    キャンセル

  • 2018/05/24 18:15

    回答に追記しました。【追記2】を参照してください。
    恐らくsetting.htmlで利用しているons-navigatorをmyNavigatorでなくinfonavigatorにすれば良いのだと思いますが。

    しかしタブバーの画面1で表示しているのはinfonavigator.htmlでありnew_info/list.htmlが表示されますよね?その内部のコードはどんなものですか?
    setting.htmlはinfotoolnavigator.htmlで表示されるようですがその画面はタブバーのどこからも呼ばれていませんよね。このあたりの画面設計は正しいですか?
    個人的には、new_info/list.htmlの中で利用している画面遷移のためのons-navigatorを、myNavigatorでなくinfonavigatorにすべきだと思います。

    キャンセル

  • 2018/05/25 10:29

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

    キャンセル

  • 2018/05/25 10:42

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

    キャンセル

  • 2018/05/25 11:58

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

    キャンセル

関連した質問

  • 解決済

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

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

  • 解決済

    ons-tabの非表示

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

  • 解決済

    ons-navigatorでのページ遷移

    前提・実現したいこと ons-navigatorでページを切り替えた後、ons-tabbarのons-tab要素を非表示にし、ons-toolbarにons-back-butto

  • 解決済

    ng-bind-htmlでのページ内リンクが機能しない

    こんにちは、いつもお世話になります。 monacaでAngularJSを使用しております。 JSONで取ってきたデータpost_contentをng-bind-htmlでバイン

  • 解決済

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

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

  • 解決済

    ons-navigetorを使った画面遷移ができない

     前提・実現したいこと MONACAでアプリ開発を行っているのですが、ツールバー上に設定画面に遷移するアイコンを配置して、ons-navigatorを使って画面遷移したいのですが、

  • 解決済

    monaca onsenUIを使用した画面遷移

     前提・実現したいこと Monacaという開発環境を利用し、最初にログインページ、ログインページ内のログインボタンを押すとメインメニュー画面に行くようなアプリケーションを作りたいの

  • 解決済

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

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

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

  • HTML5

    4193questions

    HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

  • CSS3

    2145questions

    CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

  • Monaca

    997questions

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

  • AngularJS

    571questions

    AngularJSはオープンソースのJavaScriptフレームワークです。ブラウザ上で動作するウェブアプリケーションの開発にMVCアーキテクチャを取り入れることを目的としています。

  • Onsen UI

    327questions

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