micomia

Blog

技術記事

ただのページ移動じゃない!画面遷移のしくみを深く理解する|FlutterFlow開発の質を上げる

ただのページ移動じゃない!画面遷移のしくみを深く理解する|FlutterFlow開発の質を上げる

micomia株式会社の山東です。
今回は「アプリの遷移」についてお話ししたいと思います。

「遷移」という言葉を聞くと、私には少し思い出があります。エンジニアとして現場に入って間もない頃、簡単なUI修正のタスクを任されたのですが、遷移があまりにも複雑で、その画面にどうやって辿り着けばいいのか分からず、不安になったことを今でも覚えています。

もともと個人でアプリを開発していた時は、「画面が移動できればそれでいい」と思っていて、画面同士がどのように繋がっているのかを深く考えたことはありませんでした。しかし実際の開発現場では、「どのようにその画面に遷移したか」という過程や背景が非常に重要だと気づかされました。


本記事では、そんな「遷移の裏側」に少しでも興味を持っていただけるよう、私の経験を交えながらお話ししていきます。

私が記事でお伝えしたい内容

  • 画面遷移の基本

  • FlutterFlutterFlow 遷移対応表

  • 図で理解する遷移の仕組み(どのような過程で目的の画面にたどり着くのか、その流れの理解が重要)




1.画面遷移の基本

アプリの画面遷移は、基本的に「スタック(stack)」という仕組みで管理されています。これは「積み重ねるデータ構造(LIFO: Last In, First Out)」です。

イメージとしては、付箋を重ねるようなものです。ノートに貼った付箋の上に、さらに新しい付箋を貼ると、下にある付箋は見えなくなりますよね。画面遷移も同じで、新しい画面を表示すると、もとの画面はその下に隠れた状態になります。



2.Flutter ↔ FlutterFlow 遷移対応表


Flutterの遷移種類

Flutter メソッド

FlutterFlowでの対応アクション

Push遷移

Navigator.push()

Navigate to Page → Transition Type: Push

Pop遷移

Navigator.pop()

Action: Navigate Back

Replace遷移

Navigator.pushReplacement()

Navigate to Page → Transition Type: Replace

PushAndRemoveUntil遷移

Navigator.pushAndRemoveUntil()

Navigate to Page → Transition Type: Clear Stack



3.図でわかる遷移の仕組み

次に、代表的な4つの遷移パターンを図で見ていきましょう。

  • Push遷移

  • Pop遷移

  • Replace遷移

  • PushAndRemoveUntil遷移


3-1.Push遷移

使う場面:戻る操作が必要な画面、ページ履歴を残したいとき
使わない場面:戻る必要がない画面


Before:
┌────────────┐
│   Page A   │ ← 現在表示中
└────────────┘

After push:
┌────────────┐
│   Page A   │
├────────────┤
│   Page B   │ ← 新しく開いたページ
└────────────┘

Push遷移は、現在の画面の上に新しい画面を重ねるように表示する遷移です。つまり、Page Aの上にPage Bが積み重なるイメージになります。そのため、Page Bの背後にはPage Aが残っており、Pop遷移によってPage Aへ戻ることが可能です。


3-2.Pop遷移

使う場面:前の画面に戻るとき、モーダル・ダイアログを閉じるとき
使わない場面:最初の画面(ルート)


Before:
┌────────────┐
│   Page A   │
├────────────┤
│   Page B   │ ← 現在表示中
└────────────┘

After pop:
┌────────────┐
│   Page A   │ ← 戻る先
└────────────┘

Pop遷移は、積み重ねた画面スタックをたどって前の画面に戻る遷移です。Push遷移でPage AからPage Bへ移動した場合、Pop遷移でPage BからPage Aへ戻ります。重ねた付箋を1枚ずつ剥がしていくようなイメージです。


3-3.Replace遷移

使う場面:戻る必要がない画面に移動したい、履歴を残さない遷移、特定の画面だけ残して他を削除したい
使わない場面:戻る必要があるフロー


Before:
┌────────────┐
│   Page A   │ ← 現在表示中
└────────────┘

After replace:
┌────────────┐
│   Page B   │ ← Page Aを置き換え
└────────────┘

Replace遷移は、現在の画面を新しい画面で置き換える遷移です。イメージとしては、「古い付箋を剥がして、新しい付箋に貼り替える」ような動きです。

使用例としては、LoginPageからHomePageに遷移するときなどに使われます。この場合、LoginPageの履歴は不要なため、置き換えて削除します。


3-4.PushAndRemoveUntil遷移

使う場面:ログイン後にホーム画面へ遷移、ログアウト後にログイン画面を再表示、特定の画面だけ残したい
使わない場面:戻る必要があるフロー


Before:
┌────────────┐
│  LoginPage │
├────────────┤
│  Loading   │
├────────────┤
│   Page A   │ ← 現在表示中
└────────────┘

After: 履歴をすべて削除:
┌────────────┐
│  HomePage  │ ← 新しいルート(履歴全削除)
└────────────┘

PushAndRemoveUntil遷移は、新しい画面を開くと同時に、それまでの画面履歴をすべて削除する遷移です。イメージとしては、「重ねた付箋をすべて剥がしてから、新しい付箋を貼る」ような動きになります。



4.まとめ

  • アプリの「画面遷移」は、どんなツールやフレームワーク・ノーコード(Flutter・FlutterFlowSwiftKotlinなど)を使っても、根本的な概念は同じ

  • 遷移は「スタック」という仕組みで管理されており、画面を積み重ねたり、剥がしたりすることで、ユーザーの操作に応じて画面を切り替える。

  • 画面をただ表示するだけでなく、「どのような流れでその画面にたどり着いたのか」という遷移の過程や背景を理解することが、設計の上で非常に重要。

  • 複雑なアプリでは、この「遷移の積み重ね(スタック構造)」を正しく把握していないと、思わぬバグや戻れない遷移が発生しやすい。

  • 画面遷移とは単なる「ページの切り替え」ではなく、アプリ全体の動線やユーザー体験を設計するための大切な要素


動画でもっと知りたい方はこちら


image

畑井駿佑

畑井駿佑

micomia株式会社の代表取締役です。 エンジニア、プロジェクトマネージャーを経験し、2024年にUI/UXにこだわった使いやすいシステム/アプリを開発するmicomia株式会社を設立しました。

関連記事

建設業向けマッチングアプリ開発|業界特化機能と費用感を解説
開発Tips

建設業向けマッチングアプリ開発|業界特化機能と費用感を解説

建設業向けマッチングアプリの開発について、業界特化の機能設計、案件マッチング・職人マッチングの違い、費用相場、開発期間、成功事例まで網羅。建設DX領域への参入を検討する事業者向けの実務ガイドです。

問い合わせフォームに届く営業メールが多い|迷惑を減らす対策とAI自動ブロック
AI

問い合わせフォームに届く営業メールが多い|迷惑を減らす対策とAI自動ブロック

問い合わせフォームに大量に届く営業メールに困っていませんか?営業メールが来る仕組み、従来の対策の限界、AIで自動ブロックできるFormGuardの仕組みまで、実務目線で解決策を解説します。

神戸でアプリ開発会社を選ぶ5つのポイント|失敗しない発注先の見極め方
開発Tips

神戸でアプリ開発会社を選ぶ5つのポイント|失敗しない発注先の見極め方

神戸・兵庫でアプリ開発会社を選ぶ際のチェックポイントを解説。地元対応力・実績・技術スタック・UI/UX品質・契約形態など、初めて発注する方でも失敗しないための判断軸を神戸特有の事情を踏まえて紹介します。

ユーザー視点になってアプリ開発 | micomiaでエンジニアとして働く
その他

ユーザー視点になってアプリ開発 | micomiaでエンジニアとして働く

観葉植物アプリ「でぃぐりーん」の開発事例をもとに、企画から実装・テスト・リリースまでのプロセスと、ユーザー体験を重視した開発の考え方を詳しく紹介します。

園芸のハードルを下げるには何が必要か グリラボ開発の出発点
開発Tips

園芸のハードルを下げるには何が必要か グリラボ開発の出発点

グリラボは、園芸初心者の不安を減らし、植物を育てる楽しさを広げるために生まれたアプリです。開発の出発点と狙いを紹介します。

「いつ水やりすればいいの?」にすぐ答える 育成ガイドを入れた理由
開発Tips

「いつ水やりすればいいの?」にすぐ答える 育成ガイドを入れた理由

グリラボの育成ガイドは、園芸初心者の小さな疑問にすぐ答えるための機能です。季節ごとのお手入れ支援をどう設計したかを紹介します。

初心者でも「自分にできそう」と思えること グリラボが目指した園芸体験の設計
開発Tips

初心者でも「自分にできそう」と思えること グリラボが目指した園芸体験の設計

グリラボは、園芸初心者が「自分にもできそう」と思える体験を大切にしています。心理的ハードルを下げる設計思想を紹介します。

なぜ園芸アプリに参考価格機能を入れたのか 剪定・伐採・抜根の不安に向き合う設計
開発Tips

なぜ園芸アプリに参考価格機能を入れたのか 剪定・伐採・抜根の不安に向き合う設計

グリラボは、剪定・伐採・抜根の参考価格を確認できる機能を搭載しています。料金の不透明さに向き合った理由を紹介します。

アップデート前の今、あえて残しておきたい グリラボ現バージョンの設計と次の改善テーマ
開発Tips

アップデート前の今、あえて残しておきたい グリラボ現バージョンの設計と次の改善テーマ

グリラボはアップデートを見据えつつ、現バージョンにも大きな意味があります。ローコードからスクラッチへの転換と次の改善テーマを紹介します。

植物の管理を「楽しみ」に変えるための工夫
開発Tips

植物の管理を「楽しみ」に変えるための工夫

グリラボは、雑草スタンプラリーや図鑑登録で植物とのつながりを楽しくしています。管理を楽しみに変える設計思想を紹介します。

文字を詰め込まないことが、やさしさになる グリラボのデザイン設計
開発Tips

文字を詰め込まないことが、やさしさになる グリラボのデザイン設計

グリラボは、文字を詰め込まずイラストを活用した分かりやすいデザインを採用しています。初心者向けのUI/UX設計を紹介します。

園芸アプリにAIをどう入れるか グリラボがAI機能を豊富に展開した理由
開発Tips

園芸アプリにAIをどう入れるか グリラボがAI機能を豊富に展開した理由

グリラボは、AIチャット、病気判定、活力度チェック、剪定AIなどを備えた園芸アプリです。AI機能を豊富に展開した理由を紹介します。

APIとは?仕組み・種類・活用事例をわかりやすく解説|アプリ開発での重要性
開発Tips

APIとは?仕組み・種類・活用事例をわかりやすく解説|アプリ開発での重要性

APIとは何かを初心者向けにわかりやすく解説。仕組みやREST・GraphQLなどの種類、ビジネスでの活用例まで詳しく紹介します。

アプリ内課金(IAP)とは?仕組み・種類・導入方法をわかりやすく解説
開発Tips

アプリ内課金(IAP)とは?仕組み・種類・導入方法をわかりやすく解説

アプリ内課金(IAP)とは、アプリ内でコンテンツや機能を購入できる仕組みです。種類や実装方法、ビジネス活用をわかりやすく解説します。

仕様書とは?アプリ・システム開発における役割・種類・作り方をわかりやすく解説
開発Tips

仕様書とは?アプリ・システム開発における役割・種類・作り方をわかりやすく解説

仕様書とは何かを初心者向けにわかりやすく解説。役割や種類、作り方、開発プロジェクトでの重要性まで詳しく紹介します。

SaaSとは?仕組み・メリット・代表的なサービス例をわかりやすく解説
開発Tips

SaaSとは?仕組み・メリット・代表的なサービス例をわかりやすく解説

SaaSとは何かを初心者向けにわかりやすく解説。仕組みやメリット・デメリット、代表的なサービス例、ビジネスでの活用方法まで詳しく紹介します。

WebRTCとは?仕組み・活用事例・リアルタイム通信の実装をわかりやすく解説
開発Tips

WebRTCとは?仕組み・活用事例・リアルタイム通信の実装をわかりやすく解説

WebRTCとは、ブラウザ間でリアルタイムに音声・映像・データを直接やり取りできる技術です。仕組みやビジネス活用をわかりやすく解説します。

TypeScriptとは?特徴・JavaScriptとの違い・開発での活用をわかりやすく解説
開発Tips

TypeScriptとは?特徴・JavaScriptとの違い・開発での活用をわかりやすく解説

TypeScriptとは、JavaScriptに静的型付けを追加したプログラミング言語です。特徴やメリット、ビジネス活用をわかりやすく解説します。

受託開発とパッケージ開発の違いとは?特徴・費用・選び方をわかりやすく解説
費用

受託開発とパッケージ開発の違いとは?特徴・費用・選び方をわかりやすく解説

受託開発とパッケージ開発の違いを費用・期間・柔軟性の観点で比較。自社に最適な開発手法の選び方と、ノーコード活用の第3の選択肢を解説します。

UI/UXデザインとは?違い・重要性・アプリ開発での実践方法を解説
開発Tips

UI/UXデザインとは?違い・重要性・アプリ開発での実践方法を解説

UI/UXデザインの違いや重要性、デザインプロセスを初心者向けにわかりやすく解説。アプリ開発における実践方法やビジネスへの効果まで詳しく紹介します。