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株式会社を設立しました。

関連記事

【これ一本で丸わかり】FlutterFlowとは?できること・料金・日本語対応・iOS/Android開発までわかりやすく解説
FlutterFlow

【これ一本で丸わかり】FlutterFlowとは?できること・料金・日本語対応・iOS/Android開発までわかりやすく解説

FlutterFlowとは何か、できること・料金プラン・日本語対応・信頼性をわかりやすく解説。iOS/Android/Webアプリをノーコードで開発できるローコードツールの基本と、開発実績80記事を持つmicomiaが解説します。

FlutterFlowとFlutterの違いとは?特徴・開発スピード・使い分けを徹底比較
FlutterFlow

FlutterFlowとFlutterの違いとは?特徴・開発スピード・使い分けを徹底比較

FlutterFlowとFlutterの違いを開発スピード・カスタマイズ性・必要スキルの観点で比較。プロジェクトに応じた使い分けの判断基準を解説します。

FlutterFlowとBubbleの違いとは?特徴・料金・選び方を徹底比較
FlutterFlow

FlutterFlowとBubbleの違いとは?特徴・料金・選び方を徹底比較

FlutterFlowとBubbleの違いを徹底比較。対応プラットフォーム・開発アプローチ・料金・パフォーマンスなど多角的に解説し、プロジェクトに合った選び方を紹介します。

FlutterFlowでStripe決済を導入する方法|設定手順・注意点をわかりやすく解説
FlutterFlow

FlutterFlowでStripe決済を導入する方法|設定手順・注意点をわかりやすく解説

Stripeとは何かを初心者向けにわかりやすく解説。FlutterFlowとの連携方法や決済の仕組み、導入手順、ビジネスでの活用事例まで詳しく紹介します。

ユーザーが迷わない画面体験と運営の管理画面|メディカルサークルのUI/UX②
開発Tips

ユーザーが迷わない画面体験と運営の管理画面|メディカルサークルのUI/UX②

医学部生向けノートアプリ「メディカルサークル」の画面 UX と管理画面設計。アップロード導線、ファイル種別の視認性、ゲスト→会員導線、退会フロー、ボトムナビと FAB の配置、React 製管理画面の俯瞰性を解説します。

RevenueCat でサブスクを Firestore と同期する|メディカルサークル Pro の課金実装
開発Tips

RevenueCat でサブスクを Firestore と同期する|メディカルサークル Pro の課金実装

医学部生向けノートアプリ「メディカルサークル」の有料プラン実装。RevenueCat の Entitlement Identifier の落とし穴、Firestore との二重反映、一元化された課金プロバイダ、購入の復元の検証フローまで解説します。

通報・ブロック・非表示で安心を設計する|メディカルサークルのコミュニティ機能
開発Tips

通報・ブロック・非表示で安心を設計する|メディカルサークルのコミュニティ機能

医学部生向けノートアプリ「メディカルサークル」のコミュニティ設計。通報・ブロック・コンテンツ非表示の3機能を別コレクションで分離し、ストリーム監視やセキュリティルールで安全性とパフォーマンスを両立した実装を紹介します。

医療×学術の信頼感を作るデザインシステム|メディカルサークルのUI設計
開発Tips

医療×学術の信頼感を作るデザインシステム|メディカルサークルのUI設計

医学部生向けノートアプリ「メディカルサークル」のデザインシステム。余白・角丸・色数のルール化、メディカルブルーの配色、Noto Sans JP の段階設計、共通ウィジェットの先行構築、空状態・エラー UI の作り方を解説します。

恋愛系マッチングアプリを作りたいと思ったら読む記事|開発会社が教える、作る前に詰めるべきこと
開発Tips

恋愛系マッチングアプリを作りたいと思ったら読む記事|開発会社が教える、作る前に詰めるべきこと

恋愛系マッチングアプリを作りたい方へ。開発相談を多数受けてきた開発会社の視点で、作る前に知っておくべき「アイデアの詰めが甘い」6つの失敗パターン、それでも作る価値がある条件、事前に詰めるべき3点を解説します。

省人化とは?意味・読み方と中小企業のバックオフィス業務で進める具体的な方法
DX

省人化とは?意味・読み方と中小企業のバックオフィス業務で進める具体的な方法

省人化の読み方・意味から、業務効率化・自動化との違い、中小企業のバックオフィス業務で実現する具体的な4つのパターンと3ステップの進め方、ツール選定の罠までを一本で解説します。

SNSアプリの作り方完全ガイド|開発費用・作成手順・必要機能・成功事例まとめ
開発Tips

SNSアプリの作り方完全ガイド|開発費用・作成手順・必要機能・成功事例まとめ

SNSアプリの作り方を「パッケージ開発」と「オーダーメイド開発」で徹底比較。依頼前に整理すべき機能・予算・ターゲットのポイントと、micomiaの開発実績を交えてわかりやすく解説します。

ノーコードでアプリ開発はどこまでできる?Adalo→FlutterFlow移行の実例で限界と本番化を解説
開発Tips

ノーコードでアプリ開発はどこまでできる?Adalo→FlutterFlow移行の実例で限界と本番化を解説

ノーコードツールでのアプリ開発の実態を解説。Adalo・Click・Glideなど無料で使えるノーコードツールの特徴やメリット・デメリット、初心者がつまずきやすいポイントを紹介します。

システム受託開発とは?依頼前に知るべき流れ・契約形態・費用相場
開発Tips

システム受託開発とは?依頼前に知るべき流れ・契約形態・費用相場

システム受託開発の基本から、契約形態(請負・準委任)の違い、費用相場、依頼の流れ、失敗しないパートナー選びまで体系的に解説。発注を検討中のB2B担当者・経営者向けの実務ガイドです。

要件定義が曖昧でも相談してよいのか|アプリ開発の進め方をわかりやすく解説
開発Tips

要件定義が曖昧でも相談してよいのか|アプリ開発の進め方をわかりやすく解説

要件定義が曖昧でもアプリ開発会社に相談してOK。早い段階で専門家に相談するメリットやMVPアプローチの活用法を解説。micomiaではアイデア段階からのご相談を歓迎しています。

開発後の保守運用で必要なこととは?コスト・体制・よくある課題を解説
開発Tips

開発後の保守運用で必要なこととは?コスト・体制・よくある課題を解説

開発後の保守運用で必要な業務内容・コスト目安・よくある課題を解説。障害対応やセキュリティ対策、属人化防止のポイントをmicomiaの経験をもとに紹介します。

Webアプリとネイティブアプリ、どっちが正解? 50個の事例から分析
開発Tips

Webアプリとネイティブアプリ、どっちが正解? 50個の事例から分析

Webアプリとネイティブアプリは、どちらが優れているかではなく、用途に対してどちらが適切かで決まります。大企業アプリ50件の分析フレームをもとに、選び方を整理します。

神戸でASO対策ならmicomia|App Store最適化でダウンロード数を増やす方法
開発Tips

神戸でASO対策ならmicomia|App Store最適化でダウンロード数を増やす方法

神戸でASO対策(App Store最適化)をお考えの方向けに、ASOの基本施策・効果測定方法・micomiaの支援内容をまとめて解説。アプリのダウンロード数を増やす実践的な手法を、神戸拠点の開発会社が紹介します。

サーバーサイドレンダリング(SSR)とは?
開発Tips

サーバーサイドレンダリング(SSR)とは?

サーバーサイドレンダリング(SSR)とは、Webページの描画をサーバー側で行い完成したHTMLを返す手法です。CSRとの違いやSEO効果、Next.jsなどのフレームワーク、ビジネス活用を初心者にもわかりやすく解説します。

関西のアプリ開発会社おすすめの選び方|大阪・神戸・京都で依頼する際のポイント
開発Tips

関西のアプリ開発会社おすすめの選び方|大阪・神戸・京都で依頼する際のポイント

関西エリア(大阪・神戸・京都)でアプリ開発会社を探している方向けに、選び方のポイントと地域特性をまとめました。神戸・兵庫拠点で開発を行うmicomiaの強みも紹介。地元企業との対面打ち合わせを重視したい方に。

事業計画書・補助金申請用のアプリ/システム開発見積もり|企画段階でも無料でお打ち合わせ
開発Tips

事業計画書・補助金申請用のアプリ/システム開発見積もり|企画段階でも無料でお打ち合わせ

事業計画書や補助金申請のためにアプリ・システム開発の見積もりが必要な方向けに、企画段階での見積もり対応や無料のお打ち合わせについて解説。IT導入補助金・ものづくり補助金の申請に間に合うスピード対応もご紹介します。

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