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・FlutterFlow・SwiftKotlinなど)を使っても、根本的な概念は同じ

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

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

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

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

image

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

畑井駿佑

畑井駿佑

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

関連記事

FlutterFlowでノーコード開発!特徴・できること・活用事例をわかりやすく解説

FlutterFlowでノーコード開発!特徴・できること・活用事例をわかりやすく解説

FlutterFlowとは、Googleが開発したFlutterフレームワークをベースにした、ノーコード・ローコードのアプリ開発プラットフォームです。プログラミングの知識がなくても、ドラッグ&ドロップの操作でiOS・Android・Webに対応した本格的なアプリを開発できます。

ユーザーの視点になって。FlutterFlowで叶える「心地よい」アプリの開発裏側を紹介

ユーザーの視点になって。FlutterFlowで叶える「心地よい」アプリの開発裏側を紹介

micomia株式会社のエンジニア宮城が、観葉植物育成アプリ「でぃぐりーん」開発の舞台裏を解説。植物初心者の視点で課題を洗い出し、FlutterFlowを活用した実装、AI植物判定やマップ連携の設計思想、ミリ単位で磨き込んだUI/UXテストまで、使いやすさを追求したプロセスを紹介します。アプリ開発における体験設計と品質へのこだわりが分かる内容です。

クリーンアーキテクチャとは?設計思想・メリット・実践方法をわかりやすく解説

クリーンアーキテクチャとは?設計思想・メリット・実践方法をわかりやすく解説

システム開発をしているmicomia株式会社です。クリーンアーキテクチャとは、ビジネスロジックを中心に据えた変更に強い設計手法です。今回は4層構造や活用方法をわかりやすく解説します。

ディープリンクとは?仕組み・種類・アプリ開発での活用方法をわかりやすく解説

ディープリンクとは?仕組み・種類・アプリ開発での活用方法をわかりやすく解説

ディープリンクとは、アプリ内の特定画面に直接遷移させるリンク技術です。種類や仕組み、ビジネス活用までわかりやすく解説します。

リファクタリングとは?目的・手法・開発現場での進め方をわかりやすく解説

リファクタリングとは?目的・手法・開発現場での進め方をわかりやすく解説

リファクタリングとは、プログラムの動作を変えずにコード構造を改善する作業です。手法やメリット、ビジネス活用までわかりやすく解説します。

アジャイル開発とは?特徴・メリット・ウォーターフォールとの違いをわかりやすく解説

アジャイル開発とは?特徴・メリット・ウォーターフォールとの違いをわかりやすく解説

アジャイル開発とは、短い開発サイクル(イテレーション)を繰り返しながら、少しずつソフトウェアを作り上げていく開発手法のことです。従来のウォーターフォール開発と異なり、変更や改善に柔軟に対応できるため、Webサービスやアプリ開発で広く採用されています。

MVP開発とは?意味・進め方・成功のポイントをわかりやすく解説

MVP開発とは?意味・進め方・成功のポイントをわかりやすく解説

MVP開発とは、Minimum Viable Product(実用最小限の製品)を素早く開発し、市場に投入してユーザーの反応を検証する開発手法です。必要最小限の機能だけを搭載した製品をリリースし、ユーザーからのフィードバックをもとに改善を繰り返すことで、開発リスクを抑えながらプロダクトを成長させていきます。

ノーコード開発とは?メリット・デメリット・活用事例をわかりやすく解説

ノーコード開発とは?メリット・デメリット・活用事例をわかりやすく解説

ノーコード開発とは、プログラミング(コーディング)を一切行わずに、ビジュアルな操作だけでアプリケーションやWebサイトを開発する手法です。ドラッグ&ドロップやパーツの組み合わせなど、直感的な操作でソフトウェアを構築できます。

オフショア開発とは?メリット・デメリット・成功のポイントをわかりやすく解説

オフショア開発とは?メリット・デメリット・成功のポイントをわかりやすく解説

オフショア開発とは、ソフトウェアやシステムの開発業務を、海外の開発チームや企業に委託する開発手法のことです。主にベトナム、インド、フィリピンなどのアジア諸国が委託先として選ばれることが多く、コスト削減やIT人材不足の解消を目的に、多くの日本企業が活用しています。

フロントエンドとバックエンドとは?違い・役割・技術をわかりやすく解説

フロントエンドとバックエンドとは?違い・役割・技術をわかりやすく解説

フロントエンドとは、ユーザーが直接目にする画面(UI)の部分を指し、バックエンドとは、サーバー側で動作するデータ処理やビジネスロジックの部分を指します。この2つが連携することで、Webサイトやアプリケーションは動作しています。

iOSアプリ開発とは?開発手法・言語・費用相場をわかりやすく解説

iOSアプリ開発とは?開発手法・言語・費用相場をわかりやすく解説

iOSアプリ開発とは、Apple社のiPhone・iPad向けのアプリケーションを開発することです。App Storeで配信されるアプリはすべてiOSアプリとして開発されています。

ウォーターフォール開発とは?特徴・メリット・アジャイルとの違いをわかりやすく解説

ウォーターフォール開発とは?特徴・メリット・アジャイルとの違いをわかりやすく解説

ウォーターフォール開発とは、要件定義から設計・実装・テスト・リリースまでを順番に進める開発手法です。特徴やメリット・デメリット、アジャイル開発との違いをわかりやすく解説します。

React Nativeとは?特徴・メリット・Flutterとの違いをわかりやすく解説

React Nativeとは?特徴・メリット・Flutterとの違いをわかりやすく解説

React Nativeとは、Meta(旧Facebook)が開発したクロスプラットフォームのモバイルアプリ開発フレームワークです。JavaScriptとReactの技術を使って、iOSとAndroidの両方で動作するネイティブアプリを1つのコードベースから開発できます。

Webアプリ開発とは?仕組み・技術スタック・開発手順をわかりやすく解説

Webアプリ開発とは?仕組み・技術スタック・開発手順をわかりやすく解説

Webアプリ開発とは、ブラウザ上で動作するアプリケーションを開発することです。インストール不要でURLにアクセスするだけで利用でき、Gmail、Googleマップ、Notionなど、日常的に使われている多くのサービスがWebアプリとして提供されています。

生成AIで作った仕様書、そのまま相談に持ってきてOKです!|アプリ/システム開発のmicomia

生成AIで作った仕様書、そのまま相談に持ってきてOKです!|アプリ/システム開発のmicomia

micomia株式会社ではAIを利用して仕様書や要件定義書を作成され、開発の相談に来られる方が多くいらっしゃいます。 今回は依頼にあたってどのような点が網羅されているといいかも含めて解説していきます。

SNSアプリ開発を依頼する前に知っておきたい5つのこと|アプリ開発ならmicomia

SNSアプリ開発を依頼する前に知っておきたい5つのこと|アプリ開発ならmicomia

SNSアプリ開発を依頼する前に知っておきたい5つのポイントを解説。運営体制・開発費用の内訳・機能の優先順位・自動化の仕組み・公開後の維持管理まで、失敗しないSNSアプリ開発の全体像がわかります。

良いUIでアプリを作るメリットとデメリット|UI/UX設計が必要な理由

良いUIでアプリを作るメリットとデメリット|UI/UX設計が必要な理由

アプリ開発でUI/UX設計費用を削るべきか迷っていませんか?良いUIがもたらす信頼感・継続率・紹介のしやすさといったメリットと、費用・期間増加のデメリットを整理。投資対効果から見たUI設計の重要性を解説します。

SNSアプリを運営することになったら読む記事|アプリ開発ならmicomia

SNSアプリを運営することになったら読む記事|アプリ開発ならmicomia

SNSアプリの運営で必ず直面する問題投稿・通報対応・DM法律・問い合わせ処理・アカウント停止などの課題を徹底解説。運営前に知っておくべき仕組みと体制作りのポイントをまとめています。

【開発実績】植物SNSアプリ でぃぐりーんを開発しました【iOS/Android】

【開発実績】植物SNSアプリ でぃぐりーんを開発しました【iOS/Android】

植物SNSアプリ「でぃぐりーん」の開発事例。AI植物判定・位置情報連動型購入場所シェア・植物日記機能など、初心者が迷わず使えるUI/UXをmicomiaが設計・開発した実績を紹介。

SNSアプリの作り方・依頼方法を解説|アプリ開発のmicomia

SNSアプリの作り方・依頼方法を解説|アプリ開発のmicomia

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

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